微博api接口调用教程(微博开放接口)

网友投稿 570 2023-01-05

本篇文章给大家谈谈微博api接口调用教程,以及微博开放接口对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 今天给各位分享微博api接口调用教程的知识,其中也会对微博开放接口进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

如何通过python调用新浪微博的API

1:安装python(这个不多说啦)

2:下载新浪微博SDK微博api接口调用教程的python包,解压为weibopy目录

(http://open.t.sina.com.cn/wiki/index.php/SDK)

3:申请AppKey,详见(http://open.t.sina.com.cn/wiki/index.php/FAQ)


流程:


1:通过oAuth认证,详见(http://open.t.sina.com.cn/wiki/index.php/Oauth)

微博api接口调用教程我的理解简化如下:

用户在新浪微博给的页面输入账号密码,然后微博给应用一个PIN码,这样应用通过PIN码才有权限访问该用户的信息,而应用在整个过程中是接触不到密码的,所以用户觉得很安全,后果很满意

2:获得认证之后,就可以使用微博SDK提供的API获得信息啦

3:如果想设计web或者客户端应用的话,那就继续加个GUI好啦(未完成)


代码:

#!/usr/bin/python
import webbrowser
from weibopy.auth import OAuthHandler
from weibopy.api import API
AppKey = '2525355147'
AppSecret = '2e2c7bcdfc362eace266d1f2bf83fe6b'
my_auth = OAuthHandler(AppKey , AppSecret)
webbrowser.open(my_auth.get_authorization_url())
verifier = raw_input('PIN: ').strip()
my_auth.get_access_token(verifier)
my_api = API(my_auth)
for comment in my_api.mentions():
    object = comment
    id = object.__getattribute__("id")     
    text = object.__getattribute__("text")
    print str(id) + " : " + text

如何通过python调用新浪微博的API来爬取数据

先上结论,通过公开的api如果想爬到某大v的所有数据,需要满足以下两个条件:
1、在你的爬虫开始运行时,该大v的所有微博发布量没有超过回溯查询的上限,新浪是2000,twitter是3200。
2、爬虫程序必须不间断运行。
新浪微博的api基本完全照搬twitter,其中接口的参数特性与底层的NoSQL密不可分,建议先看点Nosql数据库的设计理念有助于更好的理解api设计。
一般来说,如果决定爬某个大v,第一步先试获取该用户的基本信息,中间会包含一条最新的status,记下其中的id号作为基准,命名为baseId。
接口中最重要的两个参数:
since_id:返回ID比since_id大的微博(即比since_id时间晚的微博),默认为0。
max_id:返回ID小于或等于max_id的微博,默认为0。
出于各种原因,获取statuses的接口,固定为按id降序排列(scan_index_forward=false),即最新的statuses返回在前。假设该微博第一天上线,就一个用户,发了一百条,id是1到100。而你在该用户发了第50条的时候开始运行的爬虫,即baseId=50。

微博开放平台api 应该怎么写

前言:微博开放平台提供微博api接口调用教程了微博数据微博api接口调用教程的api接口,不仅可以直接通过api调用微博服务发布微博查询微博,更重要的是,可以在自己的网站上获得新浪微博api的授权,调用微博的某些内容,就好像微博api接口调用教程我们再网站中看到好文章要分享到微博或者其他社交网站中一样,非常方便。

下面就来探秘一番。

1.注册开发者并获取app key 和 app secret

百度很容易找到微博开放平台的入口,登录自己的微博账号,点击账号头像,会提示编辑开发者信息。

可以看到如下的页面,只需要按照提示填写,其中紧急联系人可以填自己,网站无所谓,填百度也行。

提交之后,你需要在我的应用下实名认证,上传图片时请耐心等待,有点慢而且没有上传进度。上传之后点击返回,可以跳转到新页面:

按照需要选择,然后创建自己的应用。至于这里面各种应用名词是什么意思我也不是很清楚,用着用着就熟了。我选择的是其他应用

创建之后,会收到邮件,含有app key 和 app secret 。这是获取授权的关键。

2.获取token

首页 open.weibo.com 点击api接口,会跳转到api接口说明文档页面,你会发现api有很多功能,包括创建微博,删除微博,关注/取消关注等非常多的接口,但是每个接口都需要token才能访问。token从何而来?

首先你需要获取一个code码,其次你需要有个调用接口的网址(因为我申请的是网页应用)。

设置关联的网址:

点击你的应用名,然后在左边的菜单中找到高级信息,然后就可以编辑了。

这个页面是否有些熟悉呢?授权之后,网页会跳回redirect_uri页面,并且在url后面拼上code。于是code就有了

接下来获取授权token,授权接口第二个:

代码写的比较烂,但是多少是可用的。5个必备参数值。我们已经获取了最后两个,前面两个在邮件中。代码就不贴出来了。看管自己敲一敲有利于熟悉用法,以后少不了发各种请求。

至此,我们成功授权,返回值里有需要的token值,如果返回error,请查看错误提示,或者百度错误信息。

此后只需要带着token,就可以请求到各种接口,虽然有次数限制,不过如果正常使用应该足够了。

如何用python调用新浪微博的api

与Twitter相比,新浪微博做得更好的地方是直接提供了SDK(Twitter貌似只有第三方的SDK)。而我自然是用Python SDK,一个只有几十k的玩意。
接着进入exanples文件夹(新浪这英文水平,不提了…),打开oauthSetTokenUpdate.py文件就是一个很标准的例子了。
于是照着写了一个:
view sourceprint?01 # -*- coding: utf-8 -*-
02
03 from weibopy.auth import OAuthHandler
04 from weibopy.api import API
05
06
07 consumer_key= '应用的key'
08 consumer_secret ='应用的App Secret'
09
10 auth = OAuthHandler(consumer_key, consumer_secret)
11 auth_url = auth.get_authorization_url()
12 print 'Please authorize: ' + auth_url
13 verifier = raw_input('PIN: ').strip()
14 auth.get_access_token(verifier)
15 api = API(auth)
16
17 status = api.update_status(status='hello world', lat='12.3', long='45.6') # 注意status必须是UTF-8编码的字符串,经纬度是可以不写的
18 print status.id
19 print status.text
注意consumer_key和consumer_secret需要创建一个应用才能拿到。
运行这个程序,你会发现它可耻地失败了,报出一条语法错误:
File 'C:\Documents and Settings\Administrator\Desktop\sinatpy\weibopy\api.py',
line 197 )(self, *args, post_data=post_data, headers=headers)
^SyntaxError: invalid syntax于是打开weibopy\api.py这个文件,把197行改成:
)(self, post_data=post_data, headers=headers, *args)
再运行这个程序就会提示一个URL链接,在浏览器里打开这个链接,并且给予访问权限,就会拿到一串PIN码。把这个PIN码输上去,就会发送一条推了,并且还会显示用户的Access token key和Access token secret。
可以看到整个过程是很简单的:
用你的consumer_key和consumer_secret创建一个OAuthHandler对象auth。
告诉用户访问auth.get_authorization_url(),并让用户授权这个应用。
拿到用户的PIN码,用auth.get_access_token()拿到用户的Access token key和Access token secret。
用auth创建一个API对象api。
调用api的方法,例如update_status()就是发推。详细说明可以看API文档。
当然,每次都要求用户输入PIN码也太傻了,所以在用auth.get_access_token()拿到Access token key和Access token secret之后,就可以直接用它们来创建API对象了:
view sourceprint?01 # -*- coding: utf-8 -*-
02
03 from weibopy.auth import OAuthHandler
04 from weibopy.api import API
05
06
07 consumer_key= '应用的key'
08 consumer_secret ='应用的App Secret'
09 token = '用户的Access token key'
10 tokenSecret = '用户的Access token secret'
11
12 auth = OAuthHandler(consumer_key, consumer_secret)
13 auth.setToken(token, tokenSecret)
14 api = API(auth)
15
16 status = api.update_status(status='搞定收工~')
最后想说的是新浪微博的应用审核真麻烦,没通过审核的想show下自己个性化的应用名都不行。罢了,反正我也只是玩玩而已~
看看有没有用

调用新浪微博内容接口要怎么用……JAVA有关

实现调用微博内容的Java程序如下:(注意注释)为保护隐私运行结果就不贴出来了。
import java.io.BufferedWriter;import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.Iterator;
import java.util.List;
import weibo4j.Timeline;
import weibo4j.model.Status;
import weibo4j.model.StatusWapper;
import weibo4j.model.WeiboException;

public class F { public static void main(String[] args) {
String userID="";//这里由于保护隐私请自己填写userID
String token="";//这里由于保护隐私请自己填写token
Timeline t=new Timeline();
t.client.setToken(token);
StatusWapper sw=null;
List<Status status=null;
BufferedWriter bw=null;
try{
sw=t.getUserTimelineByUid(userID);
status=sw.getStatuses();
bw=new BufferedWriter(new OutputStreamWriter(new FileOutputStream("D:\\status.txt"),"gbk"));
Iterator<Status iterator=status.iterator();
Status s=null;
while(iterator.hasNext()){
s=(Status)iterator.next();
bw.write(s.toString());//这里如果只需要微博内容可以bw.write(s.getText());
bw.newLine();
bw.flush();
}
}catch(WeiboException e){
e.printStackTrace();
System.out.println(e);
}catch(FileNotFoundException e){
e.printStackTrace();
}catch(IOException e){
e.printStackTrace();
}finally{
try {
bw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
获取当前登录用户及其所关注用户的最新微博的Java程序如下:(注意注释)为保护隐私运行结果就不贴出来了。
import java.io.BufferedWriter;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStreamWriter;
import java.util.Iterator;
import java.util.List;
import weibo4j.Timeline;
import weibo4j.model.Status;
import weibo4j.model.StatusWapper;
import weibo4j.model.WeiboException;
public class E {
public static void main(String[] args) {
String userID="";//这里由于保护隐私请自己填写userID
String token="";//这里由于保护隐私请自己填写token
Timeline t=new Timeline();
t.client.setToken(token);
StatusWapper sw=null;
List<Status status=null;
BufferedWriter bw=null;
try{
sw=t.getFriendsTimeline();
status=sw.getStatuses();
bw=new BufferedWriter(new OutputStreamWriter(new FileOutputStream("D:\\friends_status.txt"),"gbk"));
Iterator<Status iterator=status.iterator();
Status s=null;
while(iterator.hasNext()){
s=(Status)iterator.next();
bw.write(s.toString());//这里如果只需要微博内容可以bw.write(s.getText());
bw.newLine();
bw.flush();
}
}catch(WeiboException e){
e.printStackTrace();
System.out.println(e);
}catch(FileNotFoundException e){
e.printStackTrace();
}catch(IOException e){
e.printStackTrace();
}finally{
try {
bw.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}

腾讯微博API怎么用

更新:鉴于服务器压力考虑,暂时只提供API给 wordpress插件使用,见: http://www.hzlzh.com/wordpress-tencent-microblog/ [API Beta 1.04] 腾讯微博 API: .hzlzh.com/+ 你的昵称 当前版本: TX Microblog API 1.03 返回格式:json 支持调用: PHP Javascript 等各语言 获取方式: 无须密码,只需 腾讯微博 ID Json格式说明: [已经使用 json_encode()函数处理内容,请使用json_decode()解码] 具体条目说明: { "contents": [ {"content":"第1条发言","time":"发言时间","from":"发言途径"}, {"content":"第2条发言","time":"发言时间","from":"发言途径"}, {"content":"第3条发言","time":"发言时间","from":"发言途径"}, ] } PHP 调用代码范例: <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" / <?php $jsonObject = file_get_contents(' .hzlzh.com/YourID' ); $decodedArray = json_decode($jsonObject, true); echo 'Array ( [contents] = Array ( <br/'; for($i = 0;$i < 10;$i++){ echo '['.$i.'] = Array ( <br/[content] = '.$decodedArray[contents][$i][content].'<br/[time] = '.$decodedArray[contents][$i][time].'<br/[from] = '.$decodedArray[contents][$i][from].'<br/)<br/'; } echo ')) '; ? 测试地址: .hzlzh.com/demo.php?id= 你的微博ID 如 本人的ID hzlzh_com: .hzlzh.com/demo.php?id=hzlzh_com 更新说明: --------下一版预告---------- 下一版将增加参数,可选择是否获得转播及回复内容; 提供以个最近发言一览的demo; --------版本1.04---------- 去掉了个人信息资料的输出,因为显得无用; 更新了1至10条的最近发言输出; 继续优化语句,加快抓取处理速度; 增加了 JS 调用的版本,见: .hzlzh.com/js/ --------版本1.03---------- 修改消息 仅 包含 个人发言,过滤了[转播][对话]消息; 增加处理头像ICO 地址,用于获得未使用自定义头像用户的头像; 优化部分处理语句,加快执行速度; 忽略抓取错误,设置请求最大超时; --------版本1.02---------- 无须登录,获得腾讯微博相关信息; 部分用户调用无法获取发言,只能获取个人信息; 关于微博api接口调用教程和微博开放接口的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。 微博api接口调用教程的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于微博开放接口、微博api接口调用教程的信息别忘了在本站进行查找喔。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:深入理解以DEBUG方式线程的底层运行原理
下一篇:浅谈什么是SpringBoot异常处理自动配置的原理
相关文章

 发表评论

暂时没有评论,来抢沙发吧~