Python2.7:数据清洗的list index out of range问题
from csv import reader

data_rdr = reader(open('mn.csv','rb'))
header_rdr = reader(open('mn_headers.csv','rb'))

data_rows = [d for d in data_rdr]
header_rows = [h for h in header_rdr]

bad_rows = []

for h in header_rows:
    if h[0] not in data_rows[0]:
        bad_rows.append(h)

for h in bad_rows:
    header_rows.remove(h)

print len(header_rows)

 Traceback (most recent call last):
  File "/home/sewell-hoo/datafiles/test_listindex.py", line 12, in <module>
    if h[0] not in data_rows[0]:
IndexError: list index out of range

正在读《python数据处理》一书,这是第7章第2小节的内容:
处理2个CSV文件,却一直提示List index out of range,实在是想不到哪里错了。
请忽略图中配图的文件'mn_header_update.csv',两者是一个文件

图片说明

5个回答

目测你的header_rows中有[]这样的空数据,你试着打印下:
for h in header_rows:
if h == []:
print 'h is []'

Welcomedota111
YiOne_fatandstrong 谢谢你的解答
接近 2 年之前 回复

这两个数组有空数组。所以索引0就不错了。

Welcomedota111
YiOne_fatandstrong 不好意思,我又配了图片了,因该不是空数组的原因吧
接近 2 年之前 回复

你在使用前要进行检查,if not h:continue

目测你的header_rows中有[]这样的空数据,你试着打印下:
for h in header_rows:
if h == []:
print 'h is []'

List index out of range 就是数组超出索引,而代码显示错误 h[0] not in data_rows[0]:
那么要么h为空列表,要么data_rows为空列表,请下断点看一下就知道了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!