提问人:sTr8_Struggin 提问时间:6/28/2013 更新时间:11/17/2023 访问量:6526
如何在python中将复杂的嵌套列表写入不带括号的csv文件?
How to write a complex nested list to a csv file without brackets in python?
问:
因此,我无法使用该软件包将数据写入.csv文件。我的数据按以下常规格式存储:import csv
[(Time, [[ID#, MAG, Merr], [ID#, MAG, Merr]])]
我的数据集示例如下所示:
data = [(24.23, [[1.0, 18.116, 0.062], [2.0, 18.236, 0.063], [3.0, 17.855, 0.063]]),
(25.67, [[1.0, 17.968, 0.044], [2.0, 18.189, 0.051], [3.0, 17.757, 0.048]]),
(26.89, [[1.0, 17.634, 0.025], [2.0, 17.781, 0.029], [3.0, 17.454, 0.026]])]
我想将这些数据写入一个.csv文件,如下所示:
24.23, 1.0, 18.116, 0.062, 2.0, 18.236, 0.063, 3.0, 17.855, 0.063
25.67, 1.0, 17.968, 0.044, 2.0, 18.189, 0.051, 3.0, 17.757, 0.048
28.89, 1.0, 17.634, 0.025, 2.0, 17.781, 0.029, 3.0, 17.454, 0.026
我尝试了以下方法:
import csv
with open('myfile.csv', 'w') as f:
w = csv.writer(f, dialect = 'excel-tab')
w.writerows(data)
但是我在结果中得到了大量的括号。我想知道是否有更好的方法来解决这个问题?
答:
0赞
Gerrat
6/28/2013
#1
好吧,您始终可以手动解压缩数据:
data = [[a, b, c, d, e, f, g, h, i, j] for a, [[b,c,d],[e,f,g],[h,i,j]] in data]
...或者关于如何扁平化数据的 SO 上还有很多其他答案(例如。这里)
3赞
Ashwini Chaudhary
6/28/2013
#2
在将列表写入文件之前,应先将列表展平。csv
with open('myfile.csv', 'w') as f:
w = csv.writer(f, dialect='excel-tab') # use `delimiter=','` for ',' in file
for item in data:
lst = [item[0]] + [y for x in item[1] for y in x]
w.writerow(lst)
下一个:从嵌套列表中提取单个数据框列
评论