[英]Python: Missing first line when reading a CSV file
我正在尝试测试 CSV 文件中的数据。 首先,我使用 CSV 库将 CSV 文件的内容放入字典中:
#CSV is the CSV file
csvfile = open(CSV)
CSVCont = csv.DictReader(csvfile)
我做了一些测试而没有弄乱字典,我想打印出内容。 我使用了这段代码:
for row in CSVCont:
print(row)
我得到的 output 缺少第一行数据。 我的猜测是文件读错了。 有人可以帮我吗?
默认情况下, csv.DictReader
使用第一行并将其用作 header 行,用作表示行的字典中的键。
如果您的第一行不应被视为 header 行,则应提供fieldnames
参数作为标题列表。
如果您根本不想使用标题,只需使用csv.reader
代替(它将每行作为元组而不是字典发出)。
例如,使用此文件:
a,b,c
d,e,f
g,h,i
注意区别:
with open('test.csv') as f:
reader = csv.DictReader(f)
for row in reader:
print(row)
输出
OrderedDict([('a', 'd'), ('b', 'e'), ('c', 'f')])
OrderedDict([('a', 'g'), ('b', 'h'), ('c', 'i')])
尽管
with open('test.csv') as f:
reader = csv.DictReader(f, fieldnames=['1', '2', '3'])
for row in reader:
print(row)
输出
OrderedDict([('1', 'a'), ('2', 'b'), ('3', 'c')])
OrderedDict([('1', 'd'), ('2', 'e'), ('3', 'f')])
OrderedDict([('1', 'g'), ('2', 'h'), ('3', 'i')])
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.