现在的位置: 首页 > 综合 > 正文

Python脚本同时发布新浪微博和twitter

2017年12月14日 ⁄ 综合 ⁄ 共 2947字 ⁄ 字号 评论关闭

你可以在博主的新页面同样看到这篇文章

这篇文章我在写第二遍,第一遍写的很详细,可惜因为我很久没用vim了,它生气了,我不小心按错了键,写的好几百行的都没了,这肯定是上天嫌我懒得太久没写了故意来给我这么一下的,好了,不说废话了,下面就是将怎么使用python脚本来在terminal同时更新你在微博和twitter的状态了。



先说微博


首先第一步我们都是要先申请一个开发者的帐号的,关于具体的一些细节可以看看这里,里面讲了授权使用的方式和原理,像我使用的是第三方的SDK,就只是简单的看了一下,没有太深入的了解,不过想要开发SDK的同学还是可以好好研究的。


下面就是代码了:


from weibo import APIClient
from re import split
import urllib,httplib

APP_KEY = '1******671' #youre app key 
APP_SECRET = 'e623c*************bfa30b23' #youre app secret  
# callback url, your must set this URL in your "my application->appInfos-> advanced  info"
CALLBACK_URL = 'http://ww****shore.com'
ACCOUNT = 'bo******@gmail.com'#your email address
PASSWORD = '*********'     #your pw

#for getting the code contained in the callback url
def get_code(url):
    conn = httplib.HTTPSConnection('api.weibo.com')
    postdata = urllib.urlencode     ({'client_id':APP_KEY,'response_type':'code','redirect_uri':CALLBACK_URL,'action':'submit','userId':ACCOUNT,'passwd':PASSWORD,'isLoginSina':0,'from':'','regCallback':'','state':'','ticket':'','withOfficalFlag':0})
    conn.request('POST','/oauth2/authorize',postdata,{'Referer':url,'Content-Type': 'application/x-www-form-urlencoded'})
    res = conn.getresponse()
    location = res.getheader('location')
    code = location.split('=')[1]
    conn.close()
    return code

def post_weibo(post_contents):
    print "weibo posting..."
    #for getting the authorize url
    client = APIClient(app_key=APP_KEY, app_secret=APP_SECRET, redirect_uri=CALLBACK_URL)
    url = client.get_authorize_url()
    code = get_code(url)
    r = client.request_access_token(code)
    access_token = r.access_token # The token return by sina
    expires_in = r.expires_in 
    #save the access token
    client.set_access_token(access_token, expires_in)
    results = client.post.statuses__update(status=post_contents)
    return results


从上面的代码中,有一点需要注意一下那就是,get_code(),这个函数是获取了授权码,在本来的SDK中是没有这一步的,但是少了这一步我们就需要人工的在浏览区的网页上点击连接授权,而我却只想在命令行里面完成所有的事情,所以才有了这个函数,函数中是使用了httplib包模拟了web请求,并且处理了返回的信息,从而获取到了授权码。


之所以没有实现人人网,也是因为授权码的问题,可以看看人人网的开发者文档,授权方式和微博相似,不同就在于不能够我们自己通过代码发送请求来获取授权码,这也就解释了为什么人人网推荐的python
SDK都是挂在GAE上的,应该就是因为这个原因,需要我们亲自在网页上进行授权,也正式因为此,我才放弃了人人。其实他们有一个用户名密码端的服务,不过需要填表申请,表我是填了,不过后面就没有消息了,我相信如果我申请成功了,那么就可以使用和微博相同的方式了获取授权码从而获取调用API的tokens了。还是希望有聪明才智的哪位大牛搞成功了,看到这篇文章可以教一下我。



再说Twitter


看了推特的文档才知道美帝的东西就是好,他们用授权方式要更加先进,减少了授权了步骤,使用REST API也使开发者更方便的开发SDK,所以推特的SDK明显要好很多。最受欢迎的tweepy是我的第一次尝试,失败原因至今不是很明确,但因该和我使用的代理有关系,也就是说在国内使用代理上推特和Fb的要注意下,使用tweepy可能会带来的失败。除此之外,还有一点提醒大家需要注意,就是申请的twitter的App是有访问级别的限制的,默认是read only,可以自己改成 read&write 或者 read, write
& direct message 都是可以的。

后来我选择的bear的python-twitter包,安装好以后特别好用,使我的代码变的很少了,而且也兼容代理的网络条件,下面是代码:


import twitter
def post_twitter(tweets):
    print "tweets posting..."
    tw_api = twitter.Api(consumer_key='95otEcQ***********xDQQ',
             consumer_secret='1jUeoOHa********************RducGal1iA',
             access_token_key='3171230***********************LQZevkJD5spEi94',
             access_token_secret='2QjrDux***********************VRb7JBKaDGMtmI')
    results = tw_api.PostUpdate(tweets)
    return results


从上面的代码可以看出,这个SDK多么的省事儿,除了让使用者显得没有水平之外再没有别的缺点了。


至于为什么不弄一个Fb版本的,是因为Fb和tw的关系实在是比较暧昧,我绑定了从推特自动同步状态到Fb的服务,所以我的推特一有更新Fb就会跟上,我也就没有必要再做没意义的事情了。


其实我也想把这篇文章好好写写,不过写第二遍确实是有很多不想说了,以后尽量上点干货弥补一下吧。

抱歉!评论已关闭.