使用python调用新浪微博接口[python高级教程]

使用python调用新浪微博接口[python高级教程]

微博很火啊,那python是不是可以调用微博的api做一个小应用呢?答案是:必须可以,哈哈

使用python调用weibo api

# 调用的url地址 此为获取某人的个人信息的api http://open.weibo.com/wiki/2/users/show

the_url = "https://api.weibo.com/2/users/show.json?uid=105729xxxx&access_token=2.xxx__YJBzk8g4Ddfd33f10237XXXXX"

http_body = None

# 发送请求并读取返回 返回的内容是真个html源代码,或者json数据,可以通过文件输出或者包一层repr()来查看内容

req = urllib2.Request(the_url, data=http_body)

#当然也可以用此来发送请求,并读取返回的内容是真个html源代码,可以通过文件输出或者包一层repr()来查看内容

req = urllib2.Request("http://www.baidu.com", data=http_body)

resp = urllib2.urlopen(req)

print repr(resp.read())

import json

# 原配json工具

json.loads(resp.read(), object_hook=_obj_hook)

io = StringIO("["streaming API"]")

print io.getvalue()

# 输出为 ["streaming API"] io输出为一个StringIO对象 <cStringIO.StringI object at 0x1006aed80>

# 注 json工具 提供load和loads2个方法

json.load(fp[, encoding[, cls[, object_hook[, parse_float[, parse_int[, parse_constant[, object_pairs_hook[, **kw]]]]]]]])

json.loads(s[, encoding[, cls[, object_hook[, parse_float[, parse_int[, parse_constant[, object_pairs_hook[, **kw]]]]]]]])

其中fp 按照官方的解释[http://docs.python.org/2/glossary.html#term-file-object]是面向文件的系统,或者那种提供.read(),.write()方法的对象,比如上面的StringIO

s 为普通的str或者unicode,相应json数据于python数据的对应如下

[http://docs.python.org/2/library/json.html?highlight=object_hook#json-to-py-table]

JSON Python

object dict

array list

string unicode

number (int) int, long

number (real) float

true True

false False

null None

# 转换json数据

如果json数据如此

{

"ip_limit": 1000,

"limit_time_unit": "HOURS",

"remaining_ip_hits": 1000,

"remaining_user_hits": 146,

"reset_time": "2013-04-19 15:00:00",

"reset_time_in_seconds": 3286,

"user_limit": 150

}

# 关于 object_hook 非必选函数 用于替换原本钓鱼json.loads返回的一个dict,

# json.loads返回的dict如果遇到一个不存在的量 比如"abc" 则会报错,

# 于是用object_hook 返回一个自己定义的dict 让他在遇到"abc"这个不存在的变量时不直接反错

# 而是try catch一下 返回None 更稳定

def _parse_json(s):

" parse str into JsonDict "

def _obj_hook(pairs):

" convert json object to python object "

o = JsonDict()

# print pairs["list_id"]

print "text" in pairs

if "text" in pairs:

# it can output utf8

print pairs["text"]

# ---

for k, v in pairs.iteritems():

o[str(k)] = v

return o

#loads is different from load

return json.loads(s, object_hook=_obj_hook)

class JsonDict(dict):

" general json object that allows attributes to be bound to and also behaves like a dict "

def __getattr__(self, attr):

try:

return self[attr]

except KeyError:

raise AttributeError(r""JsonDict" object has no attribute "%s"" % attr)

def __setattr__(self, attr, value):

self[attr] = value

# 此 JsonDict 是dict(字典对象)的子类 它重写了 取索引的方法 __getattr__ 和 __setattr__

# 这里获取dict里的数据有个技巧 在获取JsonDict的对象时有2中方法

d1 = JsonDict();

d1["a"] = "strra"

print d1["a"]

print d1.get("a")

# 此 aaaa 并不在dict中

print d1.get("aaaa") # None

print d1["aaaa"] # key error~

# 使用get获取dict里的数据 遇到空的数据的话 可以避免error的产生 自动转成None


以上是 使用python调用新浪微博接口[python高级教程] 的全部内容, 来源链接: utcz.com/z/539986.html

回到顶部