这里的新手程序员寻求帮助。
我已经按照使用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吗?以及如何使用下一个参数来保持代码运行,直到获得与查询相对应的所有推文为止。]
[在raw_query中使用count变量,例如:
results = api.GetSearch(
raw_query="q=twitter%20&result_type=recent&since=2014-07-19&count=100")
要将结果从默认的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)