[英]How to loop itertools through a list of files?
我设法为单个文件创建此文件,以将文件中的行切成薄片。 我只想取奇数。
filename = sys.argv[1]
filename2 = sys.argv[2]
with open(filename) as f:
items = itertools.islice(f, 0, None, 2)
x = (list(items))
final = "".join(x)
with open(filename2, 'a+') as bb:
bb.write(final)
上面的代码工作正常。 但是我需要手动指定文件名。 如果我有100个文件需要切片怎么办?
示例上面的代码输出。 它将切片/删除偶数行。
Input file
a
b
c
d
e
Output file
a
c
e
我在想循环。 到目前为止,这是我的解决方案。
# Directory where it contains my pat files.
mydir = "C:\\Users\\Desktop\\Scripts\\"
files = filter(lambda x: x.endswith('.pat'), os.listdir(mydir))
# print(list(files))
# ['filepat1.pat', 'filepat2.pat', 'filepat3.pat'.......]
i = 0
new_file = 'file{}.pat'.format(i)
for file in files:
with open(file) as f:
items = itertools.islice(f, 0, None, 2)
x = (list(items))
final = "".join(x)
#print(final)
for item in items:
i +=1
new_file = 'file{}.pat'.format(i)
with open(new_file, 'a+') as ww:
ww.write(final)
我怎么了 好像它缺少循环。
如果我错了,请纠正我,但是for item in items:
的代码for item in items:
看起来很奇怪。 据我了解,您正在尝试从一个文件中提取奇数行并将其存储在新文件中,对吗?
您可以这样重写:
mydir = "C:\\Users\\Desktop\\Scripts\\"
files = filter(lambda x: x.endswith('.pat'), os.listdir(mydir))
#print(list(files))
for i, file in enumerate(files):
with open(file) as f:
items = itertools.islice(f, 0, None, 2)
x = (list(items))
final = "".join(x)
#print(final)
new_file = 'file{}.pat'.format(i)
with open(new_file, 'a+') as ww:
ww.write(final)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.