Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 13.10.2014
Сообщений: 9

Не получается создать много списков из одного большого

03.07.2023, 02:20. Показов 485. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Соответственно имеется лист read, полученный путем импортирования текстового файла.

Python
1
2
3
f = open('123.txt', 'r')
 
read = f.readlines()
Лист очень большой и его необходимо разделить на абзацы.

Как пример возьмем стихи А.С. Пушкина

PureBasic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
Я помню чудное мгновенье:
Передо мной явилась ты,
Как мимолетное виденье,
Как гений чистой красоты.
 
 
В томленьях грусти безнадежной,
В тревогах шумной суеты,
Звучал мне долго голос нежный
И снились милые черты.
 
 
Шли годы. Бурь порыв мятежный
Рассеял прежние мечты,
И я забыл твой голос нежный,
Твои небесные черты.
 
 
В глуши, во мраке заточенья
Тянулись тихо дни мои
Без божества, без вдохновенья,
Без слез, без жизни, без любви.
 
 
Душе настало пробужденье:
И вот опять явилась ты,
Как мимолетное виденье,
Как гений чистой красоты.
 
 
И сердце бьется в упоенье,
И для него воскресли вновь
И божество, и вдохновенье,
И жизнь, и слезы, и любовь.
Вот такой список будет
Python
1
read = ['Я помню чудное мгновенье:\n', 'Передо мной явилась ты,\n', 'Как мимолетное виденье,\n', 'Как гений чистой красоты.\n', ' \n', ' \n', 'В томленьях грусти безнадежной,\n', 'В тревогах шумной суеты,\n', 'Звучал мне долго голос нежный\n', 'И снились милые черты.\n', ' \n', ' \n', 'Шли годы. Бурь порыв мятежный\n', 'Рассеял прежние мечты,\n', 'И я забыл твой голос нежный,\n', 'Твои небесные черты.\n', ' \n', ' \n', 'В глуши, во мраке заточенья\n', 'Тянулись тихо дни мои\n', 'Без божества, без вдохновенья,\n', 'Без слез, без жизни, без любви.\n', ' \n', ' \n', 'Душе настало пробужденье:\n', 'И вот опять явилась ты,\n', 'Как мимолетное виденье,\n', 'Как гений чистой красоты.\n', ' \n', ' \n', 'И сердце бьется в упоенье,\n', 'И для него воскресли вновь\n', 'И божество, и вдохновенье,\n', 'И жизнь, и слезы, и любовь.']
Соответственно нужно что бы создавался новый список с каждого абзаца(с каждой пустой строки). Где то будет 2 абзаца, где то 150..
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.07.2023, 02:20
Ответы с готовыми решениями:

Python - Реализовать эффективный алгоритм получения из большого количества отсортированных списков одного отсо
Реализовать эффективный алгоритм получения из большого количества отсортированных списков одного отсортированного списка.

Создать из большого текста список списков
Добрый день! Такое задание /* Разбейте файл с текстом на предложения и слова. Считайте, что слова могут состоять...

Быстрое формирование списков большого количество данных
Здравствуйте ув.Форумчане. У меня вот такой вопрос: необходимо сделать быстрое формирование большого количества данных(порядка нескольких...

4
Любознательный
 Аватар для YuS_2
7404 / 2254 / 360
Регистрация: 10.03.2016
Сообщений: 5,213
03.07.2023, 06:17
Цитата Сообщение от serjeq Посмотреть сообщение
Как пример возьмем стихи А.С. Пушкина
для Вашего примера:
Python
1
2
3
4
with open('file.txt', 'r', encoding="utf-8") as f:
    r = f.read().split('\n \n \n')
 
print(r)
всё зависит от того, какими символами разделяются абзацы...
1
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,707
03.07.2023, 06:41
Python
1
2
3
4
5
6
7
arr = open('123.txt', encoding='utf-8').readlines()
k = 4
with open('res.txt', 'w') as f:
    for i in range(len(arr)):
        f.write(arr[i])
        if i % k == k-1:
            f.write('\n\n')
1
Заблокирован
03.07.2023, 06:52
Лучший ответ Сообщение было отмечено serjeq как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
f = open('123.txt', 'r')
read=[]
a=[]
for ln in f:
    if len(ln.strip())==0:
        if len(a):
            read.append(a)
            a=[]
    else:
        a.append(ln)
if len(a):        
    read.append(a)
f.close()    
print(read)
1
0 / 0 / 0
Регистрация: 13.10.2014
Сообщений: 9
03.07.2023, 18:22  [ТС]
Спасибо ! Этот ответ сразу заработал. Получаются списки в списке.

Добавлено через 33 минуты
Цитата Сообщение от mmi1814 Посмотреть сообщение
if len(a):        
    read.append(a)
f.close()
Кроме этого. Это вроде как вне цикла и без этого все ОК.

Добавлено через 41 минуту
Цитата Сообщение от mmi1814 Посмотреть сообщение
if len(a):        
    read.append(a)
Все, разобрался зачем это тут
Спасибо еще Раз
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.07.2023, 18:22
Помогаю со студенческими работами здесь

Слишком много аргументов в вызове функции, или как создать много файлов на рабочем столе?
Мне нужно создать на рабочем столе очень много файлов вот команда для создания 1 файла wchar_t szBuf{ 0 }; ...

Обработка большого массива функцией в цикле foreach занимает много времени
Здравствуйте! Суть скрипта заключается в том, чтоб пинговать в локалке компы и показывать их OFF или ON статусы. Реализовать идею удалось,...

создать програму которая со списков слов L1 i L2 формирует новый список L занося в него по 1ному те слова, что находяться хотяб в одном из списков
создать програму которая со списков слов L1 i L2 формирует новый список L занося в него по 1ному те слова, что находяться хотяб в одном из...

Увеличить быстродействие проги, в которой много вычислений, в т.ч. интеграл численно (физика=разлет большого числа частиц)
Ребят!привет.помогите направьте хоть на путь истинный! Дело в том что я не программист, я физик, а задача смоделировать разлет сгустка...

Создание множества мелких файлов из одного большого
Реализовать программу по созданию множества мелких файлов из одного большого, размер маленьких файлов произвольный, количество потоков...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит переходные токи и напряжения на элементах схемы. . . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru