2

我正在使用 tweepy 从 Twitter 中提取 10 条推文,并将其存储在 CSV 中,以便稍后在前端网页上显示。我的代码每 60 分钟刷新一次,在某些时候我会收到“IndexError”。

以下是确切的错误:

返回 ks[5]

IndexError:列表索引超出范围

以下是从 CSV 检索特定推文的函数:

def tweet6(self):
    with codecs.open('HELLOTWITTER.csv', 'r', encoding='utf-8', errors='ignore') as f:
        reader = csv.reader(f)
        d = {}
        for i, row in enumerate(reader):
            d[row[0]]=row[1:]
            if (i>=10):
                break    
    ks=list(d)
    return (ks[5])

此错误仅偶尔发生,但我无法弄清楚为什么会发生这种情况,尽管每次刷新整个代码时 CSV 都会将所有 10 条推文写入其中。此外,如果我再次运行代码,错误就会消失,并且网页加载时推文没有任何问题,令人惊讶!

我错过了什么?任何帮助深表感谢!谢谢!

4

1 回答 1

3

正如肯怀特在上面的评论中指出的那样。该错误是由于您尝试访问列表边界之外的索引引起的。

发生的事情是,您的 CSV 文件中有一个空白行,python 无法处理,因为您正在调用index 0它,即使它不存在,因此 python 会引发异常。

为了修复这个错误,您需要做的是检查列表中是否有足够的元素来运行您的代码。通过使用

if(len(row) < 1):
   continue

另一个可能导致问题的地方是您将列表d放入另一个列表中ks。然后您尝试返回新列表中的第 5 个对象。但是,没有对象,因为您现在有一个看起来像这样的列表

ks={{tweet,tweetyouwant,tweet},{list,two,if,present}}

当您期望列表看起来像这样时

ks={tweet,tweetyouwant,tweet}

为了解决这个问题,只需摆脱ks=list(d)并打电话d到你想打电话的任何地方ks


你的整个片段应该是这样的。

def tweet6(self):
    with codecs.open('HELLOTWITTER.csv', 'r', encoding='utf-8', errors='ignore') as f:
        reader = csv.reader(f)
        d = {}
        for i, row in enumerate(reader):

            #Verify row is within range
            if(len(row) < 1):
                continue

            #Get the rows values
            d[row[0]]=row[1:]

            #If past row 10 then break
            if (i>=10):
                break  

    #ks=list(d) #Not needed D is already a list
    return (d[5]) #return the row of the 6th tweet
于 2017-12-01T04:04:06.013 回答