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

新浪微博Python SDK笔记——发微博(一)

2013年12月09日 ⁄ 综合 ⁄ 共 2186字 ⁄ 字号 评论关闭

上一节中已经安装了Python SDK,可以在程序中引入weibo模块编写微博程序了。下面的程序的功能就是利用该模块发一条新微博,先开具体的代码:

#! /usr/bin/python

"""
引入Python SDK的包
"""
import weibo


"""
授权需要的三个信息,APP_KEY、APP_SECRET为创建应用时分配的,CALL_BACK在应用的设置网页中
设置的。【注意】这里授权时使用的CALL_BACK地址与应用中设置的CALL_BACK必须一致,否则会出
现redirect_uri_mismatch的错误。
"""
APP_KEY = '2024......'
APP_SECRET = '91a57c......'
CALL_BACK = 'http://bingbingrobot.sinaapp.com/'


def run():
        #weibo模块的APIClient是进行授权、API操作的类,先定义一个该类对象,传入参数为APP_KEY, APP_SECRET, CALL_BACK
	client = weibo.APIClient(APP_KEY, APP_SECRET, CALL_BACK)
        #获取该应用(APP_KEY是唯一的)提供给用户进行授权的url
	auth_url = client.get_authorize_url()
	#打印出用户进行授权的url,将该url拷贝到浏览器中,服务器将会返回一个url,该url中包含一个code字段(如图1所示)
	print "auth_url : " + auth_url
	#输入该code值(如图2所示)
	code = raw_input("input the retured code : ")
	#通过该code获取access_token,r是返回的授权结果,具体参数参考官方文档:
	# http://open.weibo.com/wiki/Oauth2/access_token
	r = client.request_access_token(code)
        #将access_token和expire_in设置到client对象
	client.set_access_token(r.access_token, r.expires_in)

	#以上步骤就是授权的过程,现在的client就可以随意调用接口进行微博操作了,下面的代码就是用用户输入的内容发一条新微博

	while True:
		print "Ready! Do you want to send a new weibo?(y/n)"
		choice = raw_input()
		if choice == 'y' or choice == 'Y':
			content = raw_input('input the your new weibo content : ')
			if content:
                                #调用接口发一条新微薄,status参数就是微博内容
				client.statuses.update.post(status=content)
				print "Send succesfully!"
				break;
			else:
				print "Error! Empty content!"
		if choice == 'n' or choice == 'N':
			break


if __name__ == "__main__":
	run()

图1


图2

程序执行成功后,在微博中就可以看到刚才发的新微博了,如图3所示。


图3

关于授权接口和API接口的调用

由于该SDK提供的类和函数没有详细的说明,授权过程很简单而且是固定的,可以查看模块的源代码文件weibo.py,找到系统中Python模块安装目录,就可以找到该文件,我的系统(Ubuntu)中weibo.py位于:/usr/local/lib/python2.7/dist-packages/。

关于微博操作的API,虽然没有接口的说明,但是有一定的规律。现在新浪微博开放平台的API文档(http://open.weibo.com/wiki/%E5%BE%AE%E5%8D%9AAPI)中找到需要调用的API,例如上面需要发一条微博,找到该功能的API文档(http://open.weibo.com/wiki/2/statuses/update),内容图4所示。


图4

看到该API访问的url,将url中的“/”替换成client对象的“.”,然后看到该API的HTTP请求方式,如果post则调用post接口,如果是get则调用get接口,如果该API的调用方式就是:client.statuses.update.post(status=content),参数以key=value的形式给出,具体的参数在API文档中有非常详细的说明。因此,可以看出,API的调用是非常方便的。

关于是否需要重复授权

类似的用SDK发微博的程序在网上有很多,而且大多类似,步骤都是进行授权,然后调用API,而且授权的过程是将url拷贝到浏览器中,然后将得到的code输入获取access_token。那这里有一个疑问(也是网上不少朋友问到的问题):难道每次发一条微博运行该程序时,都要进行一次授权吗?那不是很麻烦吗?而且官方文档中也说明了,授权一次是可以持续一段时间的(测试级别的是1天),这里却每次运行程序都要重新授权,是不是没必要呢?
答案是:没必要每次运行程序都进行授权,上一次成功的授权只要没有超过有效期是继续有效的。具体怎么操作呢?下一节继续。

By:
 

抱歉!评论已关闭.