gpt4 book ai didi

Python:将用户指定的某些列写入新文件

转载 作者:太空宇宙 更新时间:2023-11-03 11:16:16 25 4
gpt4 key购买 nike

如果我有一个包含多个列的文件,例如

0, 1, 2, 3, 4, 5, 6
a, b, c, d, e, f, g

我想将某些列写入新文件,其中列号存储在列表 col=[] 中。这将如何使用存储在列表中的列号的迭代来复制结果,例如:

new_file.write(line[0]+','+line[5]+','+line[6]+'\n')

我试过:

col = [0,5,6]
for line in file:
new_file.write(line[i] for i in col)

但是这不起作用,我在最后一行遇到了类型错误。最后,我想让用户输入列表,以便输出文件仅包含指定的列,这些列用“,”分隔,就像上面的示例文件一样。

最佳答案

for line in file: 迭代每一行的每个字符,而不是你想要的。

与逗号分隔文件一样,您应该使用 csv 模块正确读取字段,并使用相同的 csv 模块将它们写回:

import csv

col = [0,5,6]

with open("input.csv") as fr, open("output.csv","w",newline="") as fw:
cr = csv.reader(fr)
cw = csv.writer(fw)
cw.writerows([row[i] for i in col] for row in cr)

创造:

0, 5, 6
a, f, g

Python 2.7 需要将 open("output.csv","w",newline="") 更改为 open("output.csv","wb")

关于Python:将用户指定的某些列写入新文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51066280/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com