python urllib 和 urllib2

urllib 和 urllib2 都是接受URL請求的相關模塊,可是提供了不一樣的功能。兩個最顯著的不一樣以下:
  • urllib 僅能夠接受URL,不能建立 設置了headers 的Request 類實例;python

  • 可是 urllib 提供 urlencode 方法用來GET查詢字符串的產生,而 urllib2 則沒有。(這是 urllib 和 urllib2 常常一塊兒使用的主要緣由)web

  • 編碼工做使用urllib的urlencode()函數,幫咱們將key:value這樣的鍵值對轉換成"key=value"這樣的字符串,解碼工做能夠使用urllib的unquote()函數。(注意,不是urllib2.urlencode() )json

Get方式

# 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()

  

POST方式

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()
相關文章
相關標籤/搜索