Python: Списки
Теория: Генерация строки в цикле
Генерация строк в циклах — задача, часто возникающая на практике. Типичный пример — функция, помогающая генерировать HTML-списки. Она принимает на вход коллекцию элементов и возвращает HTML-список из них:
Как можно решить эту задачу в лоб:
- Создать переменную
resultи записать в нее<ul>. - Пройтись циклом по элементам коллекции и дописать в результирующую строку очередной элемент
<li>. - Добавить в конце
</ul>и вернутьresultиз функции.
Такой способ вполне рабочий, но для большинства языков программирования максимально неэффективный. Дело в том, что конкатенация и интерполяция порождают новую строчку вместо старой. Подобная ситуация повторяется на каждой итерации. Причем строка становится все больше и больше. Копирование строк приводит к серьезному расходу памяти и может влиять на производительность. Конечно, для большинства приложений данная проблема неактуальна из-за малого объема прогоняемых данных, но более эффективный подход не сложнее в реализации и обладает рядом плюсов. Поэтому стоит сразу приучить себя работать правильно.
Правильно, в случае с динамическими языками – формировать список, который затем с помощью метода join() можно превратить в строку:
Размер кода практически не изменился, но способ формирования результата стал другим. Вместо строки, сначала собирается список, который затем превращается в строку с помощью метода .join(). У такого подхода есть и дополнительные плюсы:
- Такой код проще отлаживать. Данные, представленные списком, легче вычленять визуально и программно.
- Список — это структура, с ним можно производить дополнительные манипуляции. С готовой строкой уже ничего особо не сделать.
Регулируя разделитель, строки можно объединять разными способами. Например, через запятую с пробелом:
Если каждое слово надо вывести на новой строчке, то в качестве разделителя используем символ перевода строки '\n':
Последний пример особенно важен. Новички часто допускают ошибку и добавляют перевод строки в момент формирования списка, а не в join(). Посмотрите на пример с нашей функцией build_HTML_list().
Правильно:
Неправильно:







