Python Pycurl的屬性與方法案例詳解
Pycurl包是一個(gè)libcurl的Python接口,由C語言編寫的,功能強(qiáng)大,速度快。由于pycurl的屬性和方法太多了,寫這篇博文記錄一下pycurl的屬性和方法。
正常安裝
pip install pycurl
如果出現(xiàn)問題,可以按照系統(tǒng)版本搜索安裝方法,比如centos7.1 安裝pycurl
通用請求方法
import pycurl,urllib
from io import BytesIO
url = 'http://www.baidu.com'
headers = [
"User-Agent:Mozilla/5.0 (iPhone; CPU iPhone OS 5_0 like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko) Version/5.1 Mobile/9A334 Safari/7534.48.3",
]
data = {
"cityListName":"",
"trade": ""
}
c = pycurl.Curl() #通過curl方法構(gòu)造一個(gè)對象
#c.setopt(pycurl.REFERER, 'http://www.baidu.com/') #設(shè)置referer
c.setopt(pycurl.FOLLOWLOCATION, True) #自動進(jìn)行跳轉(zhuǎn)抓取
c.setopt(pycurl.MAXREDIRS,5) #設(shè)置最多跳轉(zhuǎn)多少次
c.setopt(pycurl.CONNECTTIMEOUT, 60) #設(shè)置鏈接超時(shí)
c.setopt(pycurl.TIMEOUT,120) #下載超時(shí)
c.setopt(pycurl.ENCODING, 'gzip,deflate') #處理gzip內(nèi)容
# c.setopt(c.PROXY,ip) # 代理
c.fp = BytesIO()
c.setopt(pycurl.URL, url) #設(shè)置要訪問的URL
c.setopt(pycurl.HTTPHEADER,headers) #傳入請求頭
c.setopt(pycurl.POST, 1)
c.setopt(pycurl.POSTFIELDS, urllib.urlencode(data)) #傳入POST數(shù)據(jù)
c.setopt(c.WRITEFUNCTION, c.fp.write) #回調(diào)寫入字符串緩存
c.perform()
code = c.getinfo(c.HTTP_CODE) #返回狀態(tài)碼
html = c.fp.getvalue() #返回源代碼
print c.getinfo(c.TOTAL_TIME)
GET請求方法
c = pycurl.Curl()#通過curl方法構(gòu)造一個(gè)對象 c.setopt(pycurl.FOLLOWLOCATION, True)#自動進(jìn)行跳轉(zhuǎn)抓取 c.setopt(pycurl.MAXREDIRS,5)#設(shè)置最多跳轉(zhuǎn)多少次 c.setopt(pycurl.CONNECTTIMEOUT, 60) #設(shè)置鏈接超時(shí) c.setopt(pycurl.TIMEOUT,120)#下載超時(shí) c.setopt(pycurl.ENCODING, 'gzip,deflate')#處理gzip內(nèi)容 # c.setopt(c.PROXY,ip) # 代理 c.fp = BytesIO() c.setopt(pycurl.URL, url)#設(shè)置要訪問的URL c.setopt(pycurl.USERAGENT,ua) #傳入ua # c.setopt(pycurl.HTTPHEADER,self.headers) #傳入請求頭 c.setopt(c.WRITEFUNCTION, c.fp.write)#回調(diào)寫入字符串緩存 c.perform() code = c.getinfo(c.HTTP_CODE)#返回狀態(tài)碼 html = c.fp.getvalue() #返回源代碼
POST請求方法
c = pycurl.Curl()#通過curl方法構(gòu)造一個(gè)對象 c.setopt(pycurl.FOLLOWLOCATION, True)#自動進(jìn)行跳轉(zhuǎn)抓取 c.setopt(pycurl.MAXREDIRS,5)#設(shè)置最多跳轉(zhuǎn)多少次 c.setopt(pycurl.CONNECTTIMEOUT, 60) #設(shè)置鏈接超時(shí) c.setopt(pycurl.TIMEOUT,120)#下載超時(shí) c.setopt(pycurl.ENCODING, 'gzip,deflate')#處理gzip內(nèi)容 # c.setopt(c.PROXY,ip) # 代理 c.fp = BytesIO() c.setopt(pycurl.URL, url)#設(shè)置要訪問的URL c.setopt(pycurl.USERAGENT,ua ) #傳入U(xiǎn)ser-Agent # c.setopt(pycurl.HTTPHEADER,headers) #傳入請求頭 c.setopt(pycurl.POST, 1) c.setopt(pycurl.POSTFIELDS, urllib.parse.urlencode(data)) c.setopt(c.WRITEFUNCTION, c.fp.write)#回調(diào)寫入字符串緩存 c.perform() code = c.getinfo(c.HTTP_CODE)#返回狀態(tài)碼 html = c.fp.getvalue() #返回源代碼
windows訪問https
windows 訪問https的方法,需要證書
import certifi c.setopt(pycurl.CAINFO, certifi.where())
獲取網(wǎng)頁多重跳轉(zhuǎn)之后的地址
c.getinfo(pycurl.EFFECTIVE_URL) 獲取網(wǎng)頁的最終地址
記錄Cookie
c.setopt(pycurl.COOKIEFILE, "cookie_file_etherscan") #讀取cookie c.setopt(pycurl.COOKIEJAR, "cookie_file_etherscan") #設(shè)置cookie
其他屬性
pycurl的部分API:
pycurl.Curl() #創(chuàng)建一個(gè)pycurl對象的方法 pycurl.Curl(pycurl.URL, http://www.google.com.hk) #設(shè)置要訪問的URL pycurl.Curl().setopt(pycurl.MAXREDIRS, 5) #設(shè)置最大重定向次數(shù) pycurl.Curl().setopt(pycurl.CONNECTTIMEOUT, 60) pycurl.Curl().setopt(pycurl.TIMEOUT, 300) #連接超時(shí)設(shè)置 pycurl.Curl().setopt(pycurl.USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; SV1; .NET CLR 1.1.4322)") #模擬瀏覽器 pycurl.Curl().perform() #服務(wù)器端返回的信息 pycurl.Curl().getinfo(pycurl.HTTP_CODE) #查看HTTP的狀態(tài) 類似urllib中status屬性 pycurl.NAMELOOKUP_TIME 域名解析時(shí)間 pycurl.CONNECT_TIME 遠(yuǎn)程服務(wù)器連接時(shí)間 pycurl.PRETRANSFER_TIME 連接上后到開始傳輸時(shí)的時(shí)間 pycurl.STARTTRANSFER_TIME 接收到第一個(gè)字節(jié)的時(shí)間 pycurl.TOTAL_TIME 上一請求總的時(shí)間 pycurl.REDIRECT_TIME 如果存在轉(zhuǎn)向的話,花費(fèi)的時(shí)間 pycurl.HTTP_CODE HTTP 響應(yīng)代碼 pycurl.REDIRECT_COUNT 重定向的次數(shù) pycurl.SIZE_UPLOAD 上傳的數(shù)據(jù)大小 pycurl.SIZE_DOWNLOAD 下載的數(shù)據(jù)大小 pycurl.SPEED_UPLOAD 上傳速度 pycurl.HEADER_SIZE 頭部大小 pycurl.REQUEST_SIZE 請求大小 pycurl.CONTENT_LENGTH_DOWNLOAD 下載內(nèi)容長度 pycurl.CONTENT_LENGTH_UPLOAD 上傳內(nèi)容長度 pycurl.CONTENT_TYPE 內(nèi)容的類型 pycurl.RESPONSE_CODE 響應(yīng)代碼 pycurl.SPEED_DOWNLOAD 下載速度 pycurl.INFO_FILETIME 文件的時(shí)間信息 pycurl.HTTP_CONNECTCODE HTTP 連接代碼
參考文檔
http://pycurl.io/docs/latest/quickstart.html
到此這篇關(guān)于Python Pycurl的屬性與方法案例詳解的文章就介紹到這了,更多相關(guān)Python Pycurl的屬性與方法內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。
關(guān)注官方微信