我有一个文本文件 BM.txt ,内容如下:
*A0 0194 7F9E 00 0001 B7AB A0 0194 7F9E 00 0001 B7BE A0 0194 7F9E 00 0001 B7CD A0 0194 7F9E 00 0001 B7D4*
在我的代码中: 我想将元素分开26个字符。 26个字符的每个元素都是列表中的一个元素:
import csv #import csv modul using writerows function
#csv docs https://docs.python.org/3/library/csv.html
#open the file with the string element to seperate bm elements.
file = open("BM.txt", "r")
c = file.read()
#list comp that seperates the elements by 26 charackters each
neue_liste = [c[i:i+26] for i in range(0, len(c), 26)]
#creating a new file with the bm elements as comma seperated values
with open('briefmarken.csv', 'w', newline='') as f:
writer = csv.writer(f)
writer.writerows(neue_liste)
file.close()
列表理解的结果看起来很有希望:
['A0 0194 7F9E 00 0001 B7AB ', 'A0 0194 7F9E 00 0001 B7BE ', 'A0 0194 7F9E 00 0001 B7CD ',.....]
但是当我最终使用writerow()函数编写列表时。 csv 中的内容如下:
A,0, ,0,1,9,4, ,7,F,9,E, ,0,0, ,0,0,0,1, ,B,7,A,B,
A,0, ,0,1,9,4, ,7,F,9,E, ,0,0, ,0,0,0,1, ,B,7,B,E,
A,0, ,0,1,9,4, ,7,F,9,E, ,0,0, ,0,0,0,1, ,B,7,C,D,
....
这对我的工作真的足够好,但是我想知道为什么现在每个字符都用逗号分隔吗?我正在查看帖子和csv文档,但我不明白。
也许有人可以回答这个问题。
预先感谢
本
答案 0 :(得分:2)
您正在使用csv.writerows
编写字符串列表,该列表将写入几行。
此函数接受可迭代对象。因此,当传递字符串列表时,您会满足输入要求,但并非您所期望的那样:字符串被视为可迭代的,并且逐字符拆分。
要写入所有数据(每行1个字符串),请使用:
writer.writerows([x] for x in neue_liste)
(嗯,csv
模块在这种情况下几乎没有用,最好在文件句柄上使用writelines
)
使用writerow
将所有数据写到1行中(请注意最后缺少s
)
writer.writerow(neue_liste)
尽管评论很明智地建议您要根据空格再次分割字符串,然后使用:
writer.writerows(x.split() for x in neue_liste)
或
writer.writerows(map(str.split,neue_liste))