濮阳杆衣贸易有限公司

主頁 > 知識庫 > Python Pycurl的屬性與方法案例詳解

Python Pycurl的屬性與方法案例詳解

熱門標(biāo)簽:B52系統(tǒng)電梯外呼顯示E7 銀川電話機器人電話 鶴壁手機自動外呼系統(tǒng)違法嗎 萊蕪電信外呼系統(tǒng) 怎么辦理400客服電話 高德地圖標(biāo)注收入咋樣 地圖標(biāo)注多個 沈陽防封電銷電話卡 企業(yè)微信地圖標(biāo)注

Pycurl包是一個libcurl的Python接口,由C語言編寫的,功能強大,速度快。由于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)造一個對象
#c.setopt(pycurl.REFERER, 'http://www.baidu.com/')	#設(shè)置referer
c.setopt(pycurl.FOLLOWLOCATION, True)	#自動進行跳轉(zhuǎn)抓取
c.setopt(pycurl.MAXREDIRS,5)			#設(shè)置最多跳轉(zhuǎn)多少次
c.setopt(pycurl.CONNECTTIMEOUT, 60)		#設(shè)置鏈接超時
c.setopt(pycurl.TIMEOUT,120)			#下載超時
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)造一個對象
c.setopt(pycurl.FOLLOWLOCATION, True)   #自動進行跳轉(zhuǎn)抓取
c.setopt(pycurl.MAXREDIRS,5)            #設(shè)置最多跳轉(zhuǎn)多少次
c.setopt(pycurl.CONNECTTIMEOUT, 60)     #設(shè)置鏈接超時
c.setopt(pycurl.TIMEOUT,120)            #下載超時
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)造一個對象
c.setopt(pycurl.FOLLOWLOCATION, True)   #自動進行跳轉(zhuǎn)抓取
c.setopt(pycurl.MAXREDIRS,5)            #設(shè)置最多跳轉(zhuǎn)多少次
c.setopt(pycurl.CONNECTTIMEOUT, 60)     #設(shè)置鏈接超時
c.setopt(pycurl.TIMEOUT,120)            #下載超時
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 ) #傳入User-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)建一個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è)置
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 域名解析時間
pycurl.CONNECT_TIME 遠(yuǎn)程服務(wù)器連接時間
pycurl.PRETRANSFER_TIME 連接上后到開始傳輸時的時間
pycurl.STARTTRANSFER_TIME 接收到第一個字節(jié)的時間
pycurl.TOTAL_TIME 上一請求總的時間
pycurl.REDIRECT_TIME 如果存在轉(zhuǎn)向的話,花費的時間
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 文件的時間信息
pycurl.HTTP_CONNECTCODE HTTP 連接代碼

參考文檔

http://pycurl.io/docs/latest/quickstart.html

到此這篇關(guān)于Python Pycurl的屬性與方法案例詳解的文章就介紹到這了,更多相關(guān)Python Pycurl的屬性與方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 解決python3 安裝完P(guān)ycurl在import pycurl時報錯的問題
  • Python安裝pycurl失敗的解決方法
  • python pycurl驗證basic和digest認(rèn)證的方法
  • 簡單談?wù)凱ython的pycurl模塊
  • Python的pycurl包用法簡介

標(biāo)簽:呼倫貝爾 葫蘆島 安慶 呼倫貝爾 三亞 銀川 烏魯木齊 湘西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python Pycurl的屬性與方法案例詳解》,本文關(guān)鍵詞  Python,Pycurl,的,屬性,與,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python Pycurl的屬性與方法案例詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于Python Pycurl的屬性與方法案例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    雅江县| 都安| 阳泉市| 綦江县| 河源市| 平乐县| 望奎县| 墨玉县| 四会市| 厦门市| 玉环县| 井陉县| 普格县| 依兰县| 汉阴县| 阜宁县| 陆良县| 焉耆| 姚安县| 昭苏县| 浑源县| 娄底市| 台湾省| 阳西县| 庄浪县| 麦盖提县| 峨山| 左贡县| 景德镇市| 云霄县| 赤峰市| 关岭| 十堰市| 新沂市| 万山特区| 上蔡县| 家居| 南安市| 竹山县| 江安县| 卓资县|