Генераторные выражения в Python — синтаксис и примеры

19 июня 2026
Автор

Антон Ларичев

Введение

Генераторные выражения (generator expressions) — это компактный способ создания генераторов в Python без написания отдельной функции с yield. Они выглядят как списковые включения (list comprehensions), но заключены в круглые скобки вместо квадратных. Генераторные выражения создают ленивые итераторы, которые вычисляют значения по запросу и экономят память.

В этой статье мы разберём синтаксис генераторных выражений, сравним их со списковыми включениями и рассмотрим практические сценарии использования.

Синтаксис генераторного выражения

Генераторное выражение записывается в круглых скобках и имеет ту же структуру, что и списковое включение:

# Списковое включение — создаёт список в памяти
squares_list = [x ** 2 for x in range(10)]

# Генераторное выражение — создаёт ленивый итератор
squares_gen = (x ** 2 for x in range(10))

print(type(squares_list))  # <class 'list'>
print(type(squares_gen))   # <class 'generator'>

Основной синтаксис:

# Базовая форма
gen = (выражение for переменная in итерируемый_объект)

# С условием фильтрации
gen = (выражение for переменная in итерируемый_объект if условие)

# С вложенными циклами
gen = (выражение for x in iter1 for y in iter2)

Сравнение со списковыми включениями

Разница между генераторным выражением и списковым включением не только в скобках — она в способе работы с памятью:

import sys

# Списковое включение — все элементы в памяти сразу
big_list = [i * 2 for i in range(1000000)]
print(f"Список: {sys.getsizeof(big_list)} байт")  # ~8 МБ

# Генераторное выражение — только текущий элемент
big_gen = (i * 2 for i in range(1000000))
print(f"Генератор: {sys.getsizeof(big_gen)} байт")  # ~200 байт
Характеристика Списковое включение Генераторное выражение
Синтаксис [expr for x in iter] (expr for x in iter)
Тип результата list generator
Память Все элементы сразу По одному элементу
Повторный обход Да Нет
Индексация Да (lst[0]) Нет
Скорость создания Медленнее Быстрее

Использование с функциями

Генераторные выражения часто передаются напрямую в функции, которые принимают итерируемый объект. При этом внешние скобки не нужны:

# Сумма квадратов — без создания промежуточного списка
total = sum(x ** 2 for x in range(100))
print(total)  # 328350

# Поиск максимальной длины строки
words = ["генератор", "итератор", "список", "функция"]
max_len = max(len(w) for w in words)
print(max_len)  # 9

# Проверка условия для всех элементов
numbers = [2, 4, 6, 8, 10]
all_even = all(n % 2 == 0 for n in numbers)
print(all_even)  # True

# Объединение строк
names = ["Алиса", "Борис", "Вера"]
result = ", ".join(name.upper() for name in names)
print(result)  # АЛИСА, БОРИС, ВЕРА

Если вы хотите детальнее изучить Python и научиться писать эффективный код — приходите на наш большой курс Python-разработчик с нуля. На курсе 180 уроков и 80 упражнений, AI-тренажёры для практики 24/7, решение задач с живым ревью наставника, еженедельные встречи с менторами.

Фильтрация с условием if

Генераторные выражения поддерживают условие if для фильтрации элементов:

# Только чётные числа
evens = (n for n in range(20) if n % 2 == 0)
print(list(evens))  # [0, 2, 4, 6, 8, 10, 12, 14, 16, 18]

# Только непустые строки длиной больше 3
lines = ["hello", "", "hi", "world", "", "python"]
long_words = (line for line in lines if line and len(line) > 3)
print(list(long_words))  # ['hello', 'world', 'python']

Условное выражение if-else

Если нужно не фильтровать, а преобразовать значения по условию, используйте тернарный оператор в выражении:

# Замена отрицательных чисел нулём
numbers = [5, -3, 8, -1, 0, 7, -2]
clamped = (n if n > 0 else 0 for n in numbers)
print(list(clamped))  # [5, 0, 8, 0, 0, 7, 0]

# Классификация чисел
labels = ("чётное" if n % 2 == 0 else "нечётное" for n in range(5))
print(list(labels))  # ['чётное', 'нечётное', 'чётное', 'нечётное', 'чётное']

Вложенные циклы

Генераторные выражения поддерживают вложенные циклы:

# Все пары из двух списков
colors = ["красный", "синий"]
sizes = ["S", "M", "L"]
combinations = (f"{color}-{size}" for color in colors for size in sizes)
print(list(combinations))
# ['красный-S', 'красный-M', 'красный-L', 'синий-S', 'синий-M', 'синий-L']

# Разворачивание вложенного списка
matrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
flat = (num for row in matrix for num in row)
print(list(flat))  # [1, 2, 3, 4, 5, 6, 7, 8, 9]

Практический пример: обработка CSV-данных

Генераторные выражения отлично подходят для конвейерной обработки данных:

import csv

def process_sales(filepath):
    """Подсчёт суммы продаж из CSV-файла"""
    with open(filepath, 'r', encoding='utf-8') as f:
        reader = csv.DictReader(f)
        # Конвейер генераторных выражений
        amounts = (float(row['amount']) for row in reader)
        positive = (a for a in amounts if a > 0)
        return sum(positive)

# Считает сумму без загрузки всего файла в память
# total = process_sales('sales.csv')

Когда использовать генераторное выражение

Используйте генераторное выражение, когда:

  • Данные обрабатываются однократно — в sum(), max(), min(), any(), all(), join()
  • Набор данных большой и не помещается в память целиком
  • Нужно создать промежуточный этап в конвейере обработки

Используйте списковое включение, когда:

  • Нужен повторный доступ к элементам
  • Нужна индексация (result[0], result[-1])
  • Нужно знать длину (len(result))
  • Данных немного и экономия памяти не критична

Частые ошибки

  • Повторное использование генераторного выражения. После обхода генератор исчерпывается. Присваивание переменной не помогает — нужно создавать выражение заново.
  • Использование квадратных скобок вместо круглых. Это создаст список, а не генератор, и все элементы загрузятся в память.
  • Попытка получить длину генераторного выражения. Генераторы не поддерживают len(). Если длина нужна, используйте список или sum(1 for _ in gen).

Частозадаваемые вопросы

Чем генераторное выражение отличается от функции-генератора? Генераторное выражение — это однострочная конструкция для простых преобразований. Функция-генератор с yield подходит для сложной логики с несколькими условиями, циклами и состоянием.

Можно ли вложить одно генераторное выражение в другое? Да, можно передать одно генераторное выражение как итерируемый объект в другое. Это создаёт цепочку ленивых вычислений.

Генераторное выражение быстрее спискового включения? Создание генератора быстрее, так как элементы не вычисляются сразу. Но если нужен полный обход, общее время примерно одинаково. Главное преимущество — в экономии памяти.

Заключение

Генераторные выражения — элегантный и эффективный инструмент Python для создания ленивых итераторов. Они сочетают компактность списковых включений с экономией памяти генераторов. Используйте их для обработки больших наборов данных, в качестве аргументов агрегирующих функций и для построения конвейеров обработки.

Для закрепления навыков работы с генераторами и другими возможностями Python рекомендуем курс Python-разработчик с нуля. В первых 3 модулях курса доступно бесплатное содержание, что позволяет разобраться с основами языка и понять структуру курса до покупки полного доступа.

Стрелочка влевоГенераторы и yield в Python — как создавать и использоватьФункции в Python и способы их вызоваСтрелочка вправо

Постройте личный план изучения Python до уровня Middle — бесплатно!

Python — часть карты развития Backend

  • step100+ шагов развития
  • lessons30 бесплатных лекций
  • lessons300 бонусных рублей на счет

Все гайды по Python

Как отправлять запросы с помощью requests в PythonПочему Python выводит значение без команды printКак работает команда print в PythonВозможности Python для автоматизации задачРабота с JSON в Python на примерахPython get — методы получения данныхКак находить и исправлять ошибки в PythonРабота с данными через API и внешние сервисыСтруктура и оформление кода PythonОсновы Django с PythonПолезные приёмы в Python для повседневной работыИспользование locals в Python для отладкиИнтеграция PHP и PythonКак выполнять HTTPS-запросы в PythonFastAPI Python — быстрый старт: создание REST API с нуляКак работать с API в Python
Ввод целого числа в PythonВедение логов в PythonУдаление данных в Python с помощью removeОбработка исключений с помощью try/except в PythonФункция super() в Python — как вызвать метод родителяСоздание собственных контекстных менеджеров в PythonРабота с символами программирования PythonРабота с переменной X в PythonРабота с классами в PythonКак скачать Python на компьютерПростая программа на Python для начинающихОсновы Python для тех, кто начинаетЧто нового в Python 3Поддерживается ли Python 2 и стоит ли его использоватьPython 1 — с чего начиналась история языкаКоманда python print - полное руководство по выводу данныхПравила именования переменных в PythonПользовательские исключения в PythonОсновы Python coreОписание объектов PythonНаследование классов в Python — основы и примерыМножественное наследование в Python — примеры и MROКонтекстный менеджер with в Python — как работает и зачем нуженКомментарии в Python — однострочные, многострочные и docstringКакой Python выбрать для установкиКак вывести целое число с помощью print в PythonКак установить Python на Windows macOS и LinuxКак пользоваться консолью PythonКак получить последний элемент в PythonКак найти значение в PythonКак настроить PythonКак использовать print для строк в PythonКак работает интерпретатор PythonИнструкция по работе с PythonБлок finally в обработке исключений PythonЦелые числа в PythonАбстрактные классы в Python — ABC и abstractmethod
Загрузка данных PythonУправление проектами на GitHub с PythonСоздание веб-приложений на Flask PythonСоздание бота на PythonСоздание интерфейсов Python QTСоздание игр с PygameСоздание GUI в PythonКак работать со словарями в PythonРабота с библиотеками через Python PackagingРабота со временем в Python при помощи модуля timePython name — особенности переменнойМатематические операции в Python с модулем mathPython listing — что это и как использоватьPytest — тестирование на Python: полное руководствоОбработка изображений с OpenCV PythonNumPy в Python — основы и применение в задачахМашинное обучение с PythonИспользование Anaconda с PythonМодуль contextlib в Python — утилиты для контекстных менеджеровБиблиотеки Python и их применение в проектах
Возврат значений из функции в PythonВложенные функции в PythonСоздание собственных декораторов в PythonРабота с функцией map в PythonЦикл while в Python и примеры использованияОбработка чисел, введённых через input в PythonОсновные операторы в Python с примерамиУсловные выражения if else в Python для начинающихКак выполняется вызов функций call в PythonПродвинутые генераторы в Python — send, throw, close и корутиныПозиционные и именованные аргументы в PythonОбъявление переменных и управление областью видимости в PythonПередача аргументов по ссылке и по значению в PythonПередача аргументов через args и kwargs в PythonОсновные методы Python и примеры их использованияОператор match/case в Python 3.10+ — основы структурного сопоставленияПаттерны match/case в Python — деструктуризация, guard и вложенные шаблоныПрактические примеры match/case в Python — реальные сценарии примененияЛокальные и глобальные переменные в PythonЧасто используемые команды PythonКлючевые слова global и nonlocal в PythonКак создавать функции в PythonКак работает сборщик мусора в PythonКак работает область видимости переменных в PythonКак работает функция callable в PythonКак работает функция any и all в PythonКак проверить тип переменной в PythonКак передать функцию как аргумент в PythonКак использовать функцию isinstance в PythonКак использовать функцию filter в PythonКак использовать функцию filter в PythonКак использовать функцию eval безопасно в PythonКак использовать декораторы в PythonИзменяемые и неизменяемые типы данных в PythonГенераторы и yield в Python — как создавать и использоватьГенераторные выражения в Python — синтаксис и примерыФункции в Python и способы их вызоваФункции как объекты в PythonЧто такое замыкания в PythonЧто делает функция reduce в PythonЧто делает функция id в PythonАргументы по умолчанию в PythonАнонимные функции и lambda в PythonАлгоритмы на Python — примеры и объяснение
Запись данных в PythonУстановка pip в PythonУправление зависимостями requirement в PythonУправление библиотеками с помощью Python PackagingУдаление пробелов с помощью strip в PythonСтруктурирование кода в PythonСоздание исполняемого файла Python в exeРазбор traceback в модуле PythonРазбор site-packages в PythonРазбор Program Files в PythonРабота с Unicode кодировками в PythonРабота с системными функциями Python sysРабота с папкой AppData в PythonРабота с модулем logging в PythonРабота с каталогами в PythonРабота с CSV в PythonВиртуальная среда venv в Python — создание и настройкаКак создать простое приложение на PythonИспользование pip в Python для установки пакетовМодули в Python и организация кода в проектеИмпорт модулей в Python и правила подключенияРабота с файлами в Python пошаговоЧто делает компилятор Python и как он работаетПолучение строки из модуля PythonПодключение файлов в Python с includeПеременные среды в PythonСборка проекта с помощью packaging в PythonНастройка Python сервераИспользование Python на UbuntuИспользование консоли PythonИспользование кодировок в PythonИнициализация пакетов PythonИмпорт модулей PythonИмпорт имен в PythonСреда IDLE Python и базовые возможностиЧтение и запись TXT в PythonЧтение файлов в Python с помощью open file
Удаление элементов из списка PythonТипы данных в Python — обзор и рекомендацииОсновные операции со строками в PythonМетоды str в Python и обработка текстаСписки в Python и их ключевые методыСоздание списков данных в PythonРабота со строками и символами в PythonРабота со столбцами в PythonРабота со списком значений в PythonРабота с таблицами в Python с помощью DataFrameРабота с RFR в PythonРабота с пробелами в PythonРабота с массивами в PythonРабота с кортежами tuple PythonРабота с координатами X и Y в PythonРабота с ключами в PythonРабота с элементами данных PythonРабота с двоичными числами PythonРабота с данными в PythonРабота с данными NumPy PythonРабота с большими числами в PythonРабота с битами в PythonРабота с байтами в PythonЧто такое значение в Python и как его определитьМножества в Python и операции с нимиИспользование range в Python для цикловПроверка на четность в PythonПроверка числа в PythonПреобразование типов в PythonПреобразование списка в строку PythonПреобразование числа в строку в PythonПостроение графиков в PythonОпределение индекса элемента в PythonОкругление чисел в PythonОбъединение списков в Python с помощью zipМножества в PythonМассивы в Python и отличие от списковМассив чисел в PythonКортежи данных в PythonКак вычислить сумму чисел в PythonКак получить остаток от деления в PythonКак найти следующее число в PythonИспользование Unicode в PythonТип int в Python и его особенностиИндекс списка в PythonФункции для работы со строками в PythonЭлементы Python и способы доступа к нимДоступ к элементам массива в PythonДеление чисел в PythonРабота с данными в Python на практикеКак работать с числами в Python
Открыть базу знаний

Лучшие курсы по теме

Иконка молнииНовый
изображение курса

Основы Python

Антон Ларичев
AI-тренажерыAI-тренажеры
Практика в студииПрактика в студии
Гарантия
Бонусы
иконка звёздочки рейтинга4.7
3 999 ₽ 6 990 ₽
Подробнее
изображение курса

Nest.js с нуля

Антон Ларичев
AI-тренажерыAI-тренажеры
Практика в студииПрактика в студии
Гарантия
Бонусы
иконка звёздочки рейтинга4.6
3 999 ₽ 6 990 ₽
Подробнее
изображение курса

Docker и Ansible

Антон Ларичев
AI-тренажерыAI-тренажеры
Гарантия
Бонусы
иконка звёздочки рейтинга4.7
3 999 ₽ 6 990 ₽
Подробнее

Отправить комментарий