首先你需要安裝httplib2,這個可以在github上找到;
然后你需要獲得一個http連接的對象:
con = httplib2.Http()
然后你需要發起連接:
(6)resp, (5)content = con.request( (1)BAIDU_COM_API_COMMENTS, (2)method="POST", body=(3)body,headers=(4)header_data)
參數1是訪問的URL:比如sina.com
參數2是method:get,post,delete,add,set中的一個;
參數3是參數,最麻煩的一個,它需要使用urllib進行encode,如下所示:
body_data = {};
body_data['token'] = 'redoocnekot'
body_data['urllist'] = svn_url
body_data['starttime'] = start_time
body_data['endtime'] = end_time
body = urllib.urlencode(body_data)
參數4,header,奇怪的是它又不需要encode:
header_data = {'Content-Type': 'application/x-www-form-urlencoded'}
返回值5:內容
[{"author": "wangmeng09", "text": "\u4e0d\u8981\u4f7f\u7528\u9ed8\u8ba4\u4fee\u9970\u7b26", "lineno": 22, "date": "2015-03-13 11:05:00"……
返回值6:應答對象
{'status': '200', 'content-language': 'zh-cn', 'transfer-encoding': 'chunked', 'server-id': 'rd-139', 'vary': 'Accept-Language, Cookie', 'server': 'openresty/1.7.4.1', 'connection': 'keep-alive', 'date': 'Wed, 30 Mar 2016 15:08:41 GMT', 'access-control-allow-origin': '*', 'content-type': 'application/json'}
-----
注意到返回的內容里面unicode的顯示不正確,需要用string轉一下:
content_str = content.decode('raw_unicode_escape')
str='\u7f13\u5b58\u63a5'
print str.decode('raw_unicode_escape')
對應的漢字:緩存接
decode表示解碼,把字符從輸入中解出來。那么輸入是什么格式呢?按照'raw_unicode_escape'來理解。'raw_unicode_escape'表示什么呢?表示把\u開頭的字符串是個utf-8的編碼。