我希望实现以下目标:
对于一个特定的人,让我们说BarackObama,我想看到他提到的最后100次。所以不是他自己的推文,而是包含@BarackObama的其他人的推文。
我一直在试验Twitter API,虽然成功但没有成功实现上述问题。
提前多多感谢! →
答案 0 :(得分:0)
仅供参考,我找到了下面的剧本,这应该给我我需要的东西! 需要在我的服务器上安装Python,更不用说其他了。 只会出现以下问题:
<强> C:\用户\管理员\桌面和GT; get_tweets.py Traceback(最近一次调用最后一次): 文件“C:\ Users \ Administrator \ Desktop \ get_tweets.py”,第32行,in csv_writer.writerow(( '用户', '资料Tweet')) TypeError:'str'不支持缓冲区接口
这意味着什么?谢谢!
## Retrieve a user's tweets
## Sample usage -- python get_tweets.py user_name_list.txt output.csv
##import urllib2
import sys
import csv
import urllib
##import simplejson
import json as simplejson
import traceback
COUNT=100
URL_LOCATION="https://api.twitter.com/1/statuses/user_timeline.json?"
params = {'include_entities':'true',
'include_rts':'true',
'screen_name':'Ilse_.....=>fill in username here',
'count':COUNT
}
def check_unicode(text):
if isinstance(text,unicode):
text = text.encode("UTF-8","ignore")
return text
elif isinstance(text,str):
text= unicode(text,"UTF-8").encode("UTF-8","ignore")
return text
csv_writer = csv.writer(open(sys.argv[2],"wb"))
csv_writer.writerow(["User","tweet"])
user_list = open(sys.argv[1],"rb")
cnt=0
for each_user in user_list:
print(cnt)
params['screen_name']=each_user
encoded_url = urllib.urlencode(params)
API_CALL = URL_LOCATION + encoded_url
print(API_CALL)
try:
data = urllib.urlopen(API_CALL).read()
json_data = simplejson.loads(data)
for each_timeline in json_data:
csv_writer.writerow([each_user,check_unicode(each_timeline['text'])])
except:
# Some Crap Failed !!!
print(traceback.format_exc())
cnt+=1