Twitter API:如何使查询保持运行?

问题描述 投票:1回答:2

这里的新手程序员寻求帮助。

我已经按照使用Twitter的高级API的要求设置了代码。

SEARCH_TERM = '#AAPL OR #FB OR #KO OR #ABT OR #PEPCO'
PRODUCT = 'fullarchive'
LABEL = 'my_label'
r = api.request('tweets/search/%s/:%s' % (PRODUCT, LABEL), 
                {'query':SEARCH_TERM, 'fromDate':201501010000, 'toDate':201812310000})

但是,当我运行它时,每次搜索获得的最大推文数为500。我的问题是我应该添加到查询maxResults = 500吗?以及如何使用下一个参数来保持代码运行,直到获得与查询相对应的所有推文为止。]

python-3.x api dataframe twitter twitterapi-python
2个回答
0
投票

[在raw_query中使用count变量,例如:

results = api.GetSearch(
    raw_query="q=twitter%20&result_type=recent&since=2014-07-19&count=100")

0
投票

要将结果从默认的100扩展到500,是的,将maxResults像这样添加到查询中:

r = api.request('tweets/search/%s/:%s' % (PRODUCT, LABEL), 
    {
        'query':SEARCH_TERM, 
        'fromDate':201501010000, 'toDate':201812310000,
        'maxResults':500
    })

您可以使用next参数进行连续查询以获得更多结果。但是,更容易的是,您可以使用TwitterAPI类让TwitterPager为您执行此操作。这是一个例子:

from TwitterAPI import TwitterAPI, TwitterPager
SEARCH_TERM = '#AAPL OR #FB OR #KO OR #ABT OR #PEPCO'
PRODUCT = 'fullarchive'
LABEL = 'my_label'
api = TwitterAPI(<consumer key>, 
                 <consumer secret>,
                 <access token key>,
                 <access token secret>)
pager = TwitterPager(api, 'tweets/search/%s/:%s' % (PRODUCT, LABEL), 
    {
        'query':SEARCH_TERM, 
        'fromDate':201501010000, 'toDate':201812310000
    })
for item in pager.get_iterator():
    print(item['text'] if 'text' in item else item)
© www.soinside.com 2019 - 2024. All rights reserved.