一个文件包含如下信息我想将此文件转换为字符串列表列表组之间有一个空行。
pear
banana
milk
tea
coffee
结果返回:
build_list(f):
[[pear, banana], [milk, tea, coffee]]
一个文件包含如下信息我想将此文件转换为字符串列表列表组之间有一个空行。
pear
banana
milk
tea
coffee
结果返回:
build_list(f):
[[pear, banana], [milk, tea, coffee]]
这应该这样做:
with open("data.txt") as f:
res = [line.split('\n') for line in f.read().split('\n\n')]
将输入数据分成几组,然后将每组分成几行。
Stack_13328928.txt 是您的列表。请注意,输入文件中的最后一行必须是新行,否则最后一项会丢失,但我认为可以修改代码,您不需要一个空白的新行。
import csv
in_file = open("stack_13328928.txt")
CSV = csv.reader(in_file)
outer_ls = []
inter_ls = []
for i in CSV:
try:
i[0]
inter_ls += i
except:
outer_ls.append(inter_ls)
inter_ls = []
print outer_ls
尝试这个:
from itertools import groupby
def build_list(name):
with open(name, "r") as f:
return [[i.strip() for i in group] for key, group in
groupby(f, key=lambda k: (k.strip() == "")) if not key]
此解决方案甚至允许在组之间有多个空行或末尾有多个空行的退化文件。