如何在Python中使用新的Twitter API 1.1搜索?

Gee*_*_SO 3 python api django twitter json

众所周知,Twitter正在转向新的API(1.1),而旧的(1.0)正面临停电并最终终止.

我正在使用Python/Django开展一个小组项目,似乎没有一个大的Python Twitter库正在使用API​​ 1.1.我可以直接与API接口而不使用Python接口,但由于需要使用OAuth登录,我遇到了问题.

所以我有两个问题.

  1. 是否有支持Twitter API 1.1的Python库?

  2. 如果我们直接与新API接口,如下面的URL所示,考虑到我们需要使用OAuth登录,我们如何才能使其工作?

    网址: https://api.twitter.com/1.1/search/tweets.json?q=#freebandnames&since_id=24012619984051000&max_id=250126199840518145&result_type=mixed&count=4

sk8*_*123 5

Twitter模块有效.您可以使用它来要求Twitter进行身份验证,转到Twitter网站,输入用户名和密码,并在您的计算机上保存令牌.

我使用此代码搜索Twitter状态(实时搜索与标准Twitter搜索有点不同).

码:

# -*- coding: utf-8 -*-

import os
import twitter
import json
import csv

from twitter.oauth import write_token_file, read_token_file
from twitter.oauth_dance import oauth_dance

def login():
    # Go to http://twitter.com/apps/new to create an app and get these items.
    # See also http://dev.twitter.com/pages/oauth_single_token.

    APP_NAME = 'xxx'
    CONSUMER_KEY = 'xxx'
    CONSUMER_SECRET = 'xxx'
    TOKEN_FILE = '/token.txt'

    try:
        (oauth_token, oauth_token_secret) = read_token_file(TOKEN_FILE)
    except IOError, e:
        (oauth_token, oauth_token_secret) = oauth_dance(APP_NAME, CONSUMER_KEY,
                CONSUMER_SECRET)
        print e.errno
        print e

        if not os.path.isdir('out'):
            os.mkdir('out')

        write_token_file(TOKEN_FILE, oauth_token, oauth_token_secret)

    auth=twitter.oauth.OAuth(oauth_token, oauth_token_secret,CONSUMER_KEY, CONSUMER_SECRET)
    return twitter.TwitterStream(auth = auth, secure = True)

if __name__=="__main__":
    t = login()
    res = t.statuses.filter(track = "search text")

    res_list = []
    tweetfields = set()
    for r in res:
        if len(res_list)<100:
            print len(res_list)
            res_list.append(r)
            tweetfields = tweetfields.union(r.keys())
        else:
            break

    fname = '/results.csv'
    f = open(fname,'w')
    dw = csv.DictWriter(f,fieldnames=list(tweetfields))
    dw.writeheader()

    for r in res_list:
        dw.writerow({k:v.encode('utf8') if isinstance(v,unicode) else v for k,v in r.items()})
    f.close()

    print [result['text'] for result in res_list]
Run Code Online (Sandbox Code Playgroud)