新聞中心
urllib和urllib2都是接受URL請(qǐng)求的相關(guān)模塊,但是提供了不同的功能,最顯著的區(qū)別如下:

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括西鄉(xiāng)網(wǎng)站建設(shè)、西鄉(xiāng)網(wǎng)站制作、西鄉(xiāng)網(wǎng)頁制作以及西鄉(xiāng)網(wǎng)絡(luò)營(yíng)銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,西鄉(xiāng)網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到西鄉(xiāng)省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
(1)urllib僅可以接受URL,不能創(chuàng)建,設(shè)置headers的request類實(shí)例;
(2)但是urllib提供urlencode()方法用來GET查詢字符串的產(chǎn)生,而urllib2則沒有(這是urllib和urllib2經(jīng)常一起使用的主要原因)
(3)編碼工作使用urllib的urlencode()函數(shù),幫我們將key:value這樣的鍵值對(duì)轉(zhuǎn)換成‘key=value’這樣的字符串,解碼工作可以使用urllib的unquote()函數(shù)。
urllib.encode()的使用
urlencode()里面必須是字典類型
# _*_ coding:utf-8 _*_
import urllib
dic = {'derek':'編碼'}
print urllib.urlencode(dic) #derek=%E7%BC%96%E7%A0%81
m = urllib.urlencode(dic)
print urllib.unquote(m) #derek=編碼
一般HTTP請(qǐng)求提交數(shù)據(jù),需要編碼成 URL編碼格式,然后做為url的一部分,或者作為參數(shù)傳到Request對(duì)象中。
GET請(qǐng)求一般用于我們向服務(wù)器獲取數(shù)據(jù),比如說,我們用百度搜索知乎:https://www.baidu.com/s?wd=知乎
發(fā)現(xiàn)GEThttps://www.baidu.com/s?wd=%E7%9F%A5%E4%B9%8E,后面是一個(gè)長(zhǎng)長(zhǎng)的字符串,urldecode后發(fā)現(xiàn)就是知乎。
相關(guān)推薦:《Python視頻教程》
用urllib.urlencode()進(jìn)行轉(zhuǎn)碼,然后組合url。
# _*_ coding:utf-8 _*_
import urllib,urllib2
url = 'http://www.baidu.com/s'
headers = {'UserAgent':'Mozilla'}
keyword = raw_input('請(qǐng)輸入關(guān)鍵字:')
wd = urllib.urlencode({'wd':keyword})
fullurl = url + '?' + wd
print fullurl
request = urllib2.Request(fullurl,headers=headers)
response = urllib2.urlopen(request)
print response.read()
然后輸入關(guān)鍵字,爬取下對(duì)應(yīng)的內(nèi)容。
分享標(biāo)題:創(chuàng)新互聯(lián)Python教程:urllib和urllib2有什么區(qū)別
分享路徑:http://fisionsoft.com.cn/article/coijsic.html


咨詢
建站咨詢
