我有一个要解析的csv文件,list index out of range
运行程序时出现错误。
这是原始的csv文件:
test.csv
Date, Time To Process
10/26/2017 7:57:28 PM, 5
10/26/2017 7:57:46 PM, 3
10/26/2017 7:57:47 PM, 1
10/26/2017 7:57:49 PM, 1
10/26/2017 7:57:50 PM, 6
10/26/2017 7:57:52 PM, 5
这是我的代码:
import csv
with open('test.csv', 'rb') as n:
has_header = csv.Sniffer().has_header(n.read(1024))
n.seek(0)
reader = csv.reader(n)
if has_header:
next(reader)
dates = []
timeToProcess = []
for row in reader:
print row
values = row[0].split(',')
dates.append(values[0])
timeToProcess(values[1])
这将只打印csv文件的第一行,然后输出错误 timeToProcess.append(values[1]) IndexError: list index out of range
如果我将csv文件更改为每行都带有引号,则一切正常。为什么会这样,并且该程序是否可以在csv文件中不带引号的情况下运行?
test.csv(使用引号的作品)
Date, Time To Process
"10/26/2017 7:57:28 PM, 5"
"10/26/2017 7:57:46 PM, 3"
"10/26/2017 7:57:47 PM, 1"
"10/26/2017 7:57:49 PM, 1"
"10/26/2017 7:57:50 PM, 6"
"10/26/2017 7:57:52 PM, 5"
您正在使用csv.reader
并手动拆分行。这不是必需的-csv
模块的工作是为您隔离“单元格”(即使它们包含诸如逗号或换行符之类的元字符)。做就是了
with open('test.csv', 'rb') as n:
# ...
for row in reader:
dates.append(row[0])
timeToProcess(row[1]) # maybe better int(row[1])?
另外,请遵守PEP-8(Python代码样式指南) -每个缩进级别4个空格。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句