2015-11-16 3 views
-1

У меня есть текстовый файл и в основном его куча персонажей, которые я собираюсь делать, но у меня возникли проблемы с его расщеплением.Как я могу разделить текстовый файл по абзацу?

это выглядит следующим образом:

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 35 36 37 

39 40 
41 42 

Я хочу, чтобы разделить его на «пункта», а затем оттуда каждой линии. Я знаю, как читать функцию и все, но все, что я пытаюсь, не работает, как делать split ('\ n \ n'). Есть идеи?

+0

что произойдет, если вы 'раскол ('\ п \ п')'? –

+0

Я просто получаю все числа в одной строке с '\ n'. это странно – ekw95

+3

прочитать весь файл, а затем сделать 'split ('\ n \ n')' like 'filobj.read(). split ('\ n \ n')' –

ответ

1

Это на самом деле гораздо проще, чем вы делаете это:

10. Read each line in and append them together as long 
    as the next line is not empty. 
    When you do encounter a blank line, 
    split the current "paragraph" with ` `. 

20. Goto 10 
1

ли это выглядеть как то, что вы хотите:

txt=open("nums.txt").read() 
[[x for x in ilist if len(x) > 0] for ilist in map(lambda x : x.split("\n"),txt.split("\n\n"))] 

[['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 35 36 37'], ['39 40', '41 42']]

Если вы хотите их все в виде целых чисел, то :

map (lambda x : map(lambda x :reduce (lambda z,y: z+[int(y)] if y.isdigit() else z,x.split(),[]),x),[[x for x in ilist if len(x) > 0] for ilist in map(lambda x : x.split("\n"),txt.split("\n\n"))]) 

, который дает O/P:

[[[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, 35, 36, 37]], [[39, 40], [41, 42]]]

Смежные вопросы