urllib 僅能夠接受URL,不能建立 設置了headers 的Request 類實例;python
可是 urllib 提供 urlencode
方法用來GET查詢字符串的產生,而 urllib2 則沒有。(這是 urllib 和 urllib2 常常一塊兒使用的主要緣由)web
編碼工做使用urllib的urlencode()
函數,幫咱們將key:value
這樣的鍵值對轉換成"key=value"
這樣的字符串,解碼工做能夠使用urllib的unquote()
函數。(注意,不是urllib2.urlencode() )json
# urllib2_get.py import urllib #負責url編碼處理 import urllib2 url = "http://www.baidu.com/s" word = {"wd":"傳智播客"} word = urllib.urlencode(word) #轉換成url編碼格式(字符串) newurl = url + "?" + word # url首個分隔符就是 ? headers={ "User-Agent": "Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.103 Safari/537.36"} request = urllib2.Request(newurl, headers=headers) response = urllib2.urlopen(request) print response.read()
import urllib import urllib2 # POST請求的目標URL url = "http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule&smartresult=ugc&sessionFrom=null" headers={"User-Agent": "Mozilla...."} formdata = { "type":"AUTO", "i":"i love python", "doctype":"json", "xmlVersion":"1.8", "keyfrom":"fanyi.web", "ue":"UTF-8", "action":"FY_BY_ENTER", "typoResult":"true" } data = urllib.urlencode(formdata) request = urllib2.Request(url, data = data, headers = headers) response = urllib2.urlopen(request) print response.read()