亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

對python3 urllib包與http包的使用詳解

 更新時間:2018年05月10日 16:14:23   作者:ZJE_ANDY  
今天小編就為大家分享一篇對python3 urllib包與http包的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

urllib包和http包都是面向HTTP協(xié)議的。其中urllib主要用于處理 URL,使用urllib操作URL可以像使用和打開本地文件一樣地操作。而 http包則實現(xiàn)了對 HTTP協(xié)議的封裝,是urllib.request模塊的底層。

1.urllib包簡介

2. http 包簡介

1.urllib包簡介

urllib包主要模塊有:

1.urllib.request -----用于打開 URL網址;

2.urllib.error ---------定義了常見的urllib.request會引發(fā)的異常;

3.urllib.parse---------用于解析 URL;

具體方法:

urllib.request.urlopen( url,data,proxies ) :用于打開 url

參數(shù)如下:

url:要進行操作的 URL地址

data:可選項。向URL 傳遞的數(shù)據(jù)。

proxies:可選項。使用的代理地址

import urllib.request
url = 'http://www.baidu.com'   #網頁為百度首頁
respone = urllib.request.urlopen(url) #打開url地址,并返回一個 HTTPRespone實例
html = respone.read().decode('utf-8') #調用實例的 read()方法,并用 utf-8進行解碼處理。就得出完整的百度的HTML文件
print(html) 

部分打印結果:

<html>
<head>
 
 <meta http-equiv="content-type" content="text/html;charset=utf-8">
 <meta http-equiv="X-UA-Compatible" content="IE=Edge">
	<meta content="always" name="referrer">
 <meta name="theme-color" content="#2932e1">
 <link rel="shortcut icon" href="/favicon.ico" rel="external nofollow" type="image/x-icon" />
 <link rel="search" type="application/opensearchdescription+xml" href="/content-search.xml" rel="external nofollow" title="百度搜索" /> 
 <link rel="icon" sizes="any" mask  rel="external nofollow" >

urllib.request.urlretrieve(url,filename,reporthook,data) :用于將 URL的HTML文件下載并保存為本地文件

參數(shù)如下:

url:要下載的網頁

filename:保存在主機的路徑,可選項。

reporthook:一個回調函數(shù),可選項。

data:發(fā)送的數(shù)據(jù),一般用于 post,可選項。

特別:關于urlretrieve()的回調函數(shù)reporthook:可以用來顯示下載的進度,幾乎已經封裝好

import urllib.request
def callbackfunc(blocknum, blocksize, totalsize): #這三個參數(shù)是由 urlretrieve自動賦值的
 '''回調函數(shù)
 @blocknum: 已經下載的數(shù)據(jù)塊
 @blocksize: 數(shù)據(jù)塊的大小
 @totalsize: 遠程文件的大小
 '''
 percent = 100.0 * blocknum * blocksize / totalsize
 if percent > 100:
  percent = 100
 print( "%.2f%%"% percent) #保留兩位小數(shù)
url = 'http://www.sina.com'
local = 'd:\\sina.html'        #下載的html文件保存在 d盤的sina.html里
urllib.request.urlretrieve(url,local,callbackfunc) #沒下載完一個數(shù)據(jù)塊,就會執(zhí)行回調函數(shù)一次

執(zhí)行結果:

//只顯示局部 
0.00% 
1.38% 
2.76% 
4.13% 
5.51% 
6.89% 

2. http包簡介

http包提供了 HTTP協(xié)議的一些功能,主要模塊有:

http.client --- 底層的 HTTP 協(xié)議的一些功能,可以為 urllib.request 模塊所用

http.server --- 提供了基于 socketserver模塊的基本 HTTP服務器類

http.cookies --- cookies 的管理工具

http.client :

HttpClient不是一個瀏覽器。它是一個客戶端的HTTP通信實現(xiàn)庫。HttpClient的目標是發(fā)送和接收HTTP報文。

兩個主要類(用于客戶端):

HTTPConnection :基于HTTP協(xié)議的客戶端,指定 URL(網址) 后,可以 發(fā)送請求報文 和 接收響應報文

HTTPRespone :基于 HTTP 協(xié)議的服務端回應。一旦用 HTTPConnection 成功連接,可以調用相關方法返回該實例(HTTPRequest實例)。

(1)HTTPConnection 的方法:

構造方法: HTTPConnection( host,port,[timeout] ) 返回一個HTTPConnection 實例

host:表示主機域名或 ip 地址

port:表示端口

timeout:阻塞操作將會在給定時間后超時。可選項

發(fā)送請求報文方法:HTTPConnection.request( method,url,body =None,headers = {} )

method:發(fā)送的操作,一般為 GET 或者 POST

url :進行操作的 url

body :所發(fā)送的數(shù)據(jù)

headers:發(fā)送的 HTTP頭部,是一個字典類型

獲取響應報文方法:HTTPConnection.getrespone( )

關閉與服務器的連接: HTTPConne.close()

發(fā)送一個頭部:HTTPConnection.putheader( header,args[ ] ) #頭部以一個字典方式發(fā)送

發(fā)送一個空白行到服務器,標志頭部Header的結束:HTTPConnection.endheaders( )

發(fā)送數(shù)據(jù)到服務器:HTTPConnection.send( data ) ,應該在endheaders()之后 和 getrespone()之前調用。

(2)HTTPRespone:

HTTPRespone對象:一旦用 HTTPConnection 成功連接,可以調用HTTPConnection.getrespone()返回該實例(HTTPRequest實例)。

HTTPRespone.getheader(name) :返回頭部中的 name 字段對應的值

HTTPRespone.getheaders( ) :以元組的方式返回整個頭部的信息

HTTPRespone.read() :返回響應報文中的body部分,也即正文部分

HTTPRespone.status #返回狀態(tài)碼

HTTPRespone.version #返回 HTTP協(xié)議版本

http 包應用實例 。

from http.client import HTTPConnection

con = HTTPConnection('www.baidu.com',80)
con.request('GET','/')   #發(fā)送請求報文
res = con.getresponse()   #獲取響應報文對象
print(res.status) #200 (表示狀態(tài)碼)
print(res.reason) #OK	 (表示狀態(tài)碼對應的意義)
print(res.read().decode('utf-8')) #打印www.baidu.com的html

以上這篇對python3 urllib包與http包的使用詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Python圖像處理庫PIL的ImageFilter模塊使用介紹

    Python圖像處理庫PIL的ImageFilter模塊使用介紹

    這篇文章主要介紹了Python圖像處理庫PIL的ImageFilter模塊使用介紹,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • 使用PyInstaller?打包配置文件

    使用PyInstaller?打包配置文件

    這篇文章主要介紹了使用PyInstaller?打包配置文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • 一則python3的簡單爬蟲代碼

    一則python3的簡單爬蟲代碼

    最近一直在學習Python,還有網絡爬蟲,于是就想起來把2者結合一下,所以就有了本文。
    2014-05-05
  • Python基于Gensim實現(xiàn)文本相似度/匹配/查重

    Python基于Gensim實現(xiàn)文本相似度/匹配/查重

    Gensim是基于Python語言的自然語言處理庫,用來主題建模、文本相似度等文本處理任務,下面我們就來看看如何使用Gensim實現(xiàn)文本相似度/匹配/查重等操作吧
    2024-03-03
  • Python中函數(shù)的基本定義與調用及內置函數(shù)詳解

    Python中函數(shù)的基本定義與調用及內置函數(shù)詳解

    這篇文章主要給大家介紹了關于Python中函數(shù)的基本定義與調用及內置函數(shù)的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Python具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • Python實現(xiàn)對文件進行單詞劃分并去重排序操作示例

    Python實現(xiàn)對文件進行單詞劃分并去重排序操作示例

    這篇文章主要介紹了Python實現(xiàn)對文件進行單詞劃分并去重排序操作,涉及Python文件讀取、字符串遍歷、拆分、排序等相關操作技巧,需要的朋友可以參考下
    2018-07-07
  • 解決pycharm回車之后不能換行或不能縮進的問題

    解決pycharm回車之后不能換行或不能縮進的問題

    今天小編就為大家分享一篇解決pycharm回車之后不能換行或不能縮進的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • 從0到1使用python開發(fā)一個半自動答題小程序的實現(xiàn)

    從0到1使用python開發(fā)一個半自動答題小程序的實現(xiàn)

    這篇文章主要介紹了從0到1使用python開發(fā)一個半自動答題小程序的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • python卸載后再次安裝遇到的問題解決

    python卸載后再次安裝遇到的問題解決

    這篇文章主要給大家介紹了關于python卸載后再次安裝遇到問題解決的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用python具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-07-07
  • python中sys模塊是做什么用的

    python中sys模塊是做什么用的

    在本篇文章里小編給大家分享了一篇關于python中sys模塊的用法及相關基礎知識點,有興趣的朋友們可以參考下。
    2020-08-08

最新評論