博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
新浪微博Python SDK笔记——发微博(一)
阅读量:7070 次
发布时间:2019-06-28

本文共 2291 字,大约阅读时间需要 7 分钟。

上一节中已经安装了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':			breakif __name__ == "__main__":	run()
图1
图2
程序执行成功后,在微博中就可以看到刚才发的新微博了,如图3所示。
图3

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

 

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

关于微博操作的API,虽然没有接口的说明,但是有一定的规律。现在新浪微博开放平台的API文档()中找到需要调用的API,例如上面需要发一条微博,找到该功能的API文档(),内容图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:
 

 

你可能感兴趣的文章
浏览器被hao.360.cn劫持怎么办
查看>>
bzoj3068: 小白树
查看>>
Dubbo学习总结(3)——Dubbo-Admin管理平台和Zookeeper注册中心的搭建
查看>>
每天一个linux命令(5):rm 命令
查看>>
浅谈HTTP中Get与Post的区别
查看>>
【汇编】1.汇编环境的搭建:DOSBox的安装
查看>>
requests 简单爬虫
查看>>
datatable&list<T>
查看>>
【Python3爬虫】selenium入门
查看>>
C语言语法
查看>>
Ruby判断文件是否存在
查看>>
servlet中避免405错误的产生
查看>>
Git的checkout, reset, revert
查看>>
取余递归
查看>>
Java金钱小写转大写
查看>>
林小宅的点名册
查看>>
常用算法Java实现之直接插入排序
查看>>
《第一行代码》书籍阅读笔记
查看>>
java基础知识点复习
查看>>
[Hive_add_10] Hive 的 serde (序列化 & 反序列化) 操作
查看>>