色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

詳解python內置模塊urllib

瀏覽:19日期:2022-07-11 18:07:58

urllib 是 python 的內置模塊, 主要用于處理url相關的一些操作,例如訪問url、解析url等操作。

詳解python內置模塊urllib

urllib 包下面的 request 模塊主要用于訪問url,但是用得太多,因為它的光芒全都被 requests 這個第三方庫覆蓋了,最常用的還是 parse 模塊。 寫爬蟲過程中,經常要對url進行參數的拼接、編碼、解碼,域名、資源路徑提取等操作,這時 parse 模塊就可以排上用場。

一、urlparse

urlparse 方法是把一個完整的URL拆分成不同的組成部分,你可以根據自己的需求提取其中的某部分內容。 返回結果 ParseResult 是 namedtuple 的子類,由以下10部分組成,每部分既可以通過名字獲取也可以通過下表索引得到。

詳解python內置模塊urllib

>>> from urllib import parse>>> url = ’https://mp.weixin.qq.com/s?__biz=MjM5MzgyODQxMQ==&mid=2650366919&idx=1&sn=1b36a9f2c0921cdeac52942ec591a923#rd’>>> result = parse.urlparse(url)# 返回ParseResult對象>>> print(result)ParseResult(scheme=’https’, netloc=’mp.weixin.qq.com’, path=’/s’, params=’’, query=’__biz=MjM5MzgyODQxMQ==&mid=2650366919&idx=1&sn=1b36a9f2c0921cdeac52942ec591a923’, fragment=’rd’)# 通過下標獲取協議>>> result[0]’https’# 協議>>> result.scheme’https’# url資源路徑>>> result.path’/s’# 查詢參數>>> result.query’__biz=MjM5MzgyODQxMQ==&mid=2650366919&idx=1&sn=1b36a9f2c0921cdeac52942ec591a923’# 獲取主機名>>> result.hostname’mp.weixin.qq.com’

二、parse_qs

parse_qs 方法是將查詢參數這部分內容從字符串轉換成字典對象

>>> parse.parse_qs(result.query){’__biz’: [’MjM5MzgyODQxMQ==’], ’mid’: [’2650366919’], ’idx’: [’1’], ’sn’: [’1b36a9f2c0921cdeac52942ec591a923’]}>>>

每個參數名對應一個列表對象,這是因為在url規范中,一個參數名可以有多個值,例如: a=1&a=2,通常在實際應用場景中一般一個參數名只會對應一個值。

你可以用一行代碼將列表轉化為字符串

>>> {name: value[0] for name, value in parse.parse_qs(result.query).items()}{’__biz’: ’MjM5MzgyODQxMQ==’, ’mid’: ’2650366919’, ’idx’: ’1’, ’sn’: ’1b36a9f2c0921cdeac52942ec591a923’}

三、urlencode

反過來,如果將一個字典對象想轉換為url中的查詢參數,那么就可以使用urlencode方法。

>>> d = {’__biz’: ’MjM5MzgyODQxMQ==’, ’mid’: ’2650366919’, ’idx’: ’1’}>>> parse.urlencode(d)’__biz=MjM5MzgyODQxMQ%3D%3D&mid=2650366919&idx=1’

四、quote

在URL的標準規范中,url 只允許數字、字母和部分特殊符號的存在,如果有中文和某些特殊符號,就需要使用UTF-8進行編碼,將這些字符轉換成 %XX 的形式,例如: 【中】UTF-8編碼的結果是:

>>> '中'.encode()b’xe4xb8xad’

那么瀏覽器實際上會把【中】轉換成 %e4%b8%ad

詳解python內置模塊urllib

在python中,就可以用 quote 方法進行URL編碼,對于特殊符號,也會進行成對應的16進制符號, 例如 【=】 就轉換成了 %3D 。

>>> parse.quote('q=中')’q%3D%E4%B8%AD’>>>

quote_plus 可以將空格編碼成“+”

>>> parse.quote_plus('a b')’a+b’>>> parse.quote('a b')’a%20b’

五、unquote

unquote 是 quote 的逆向過程,稱之為URL解碼,解碼方便開發者閱讀

>>> parse.unquote('q%3D%E4%B8%AD')’q=中’

以上就是詳解python內置模塊urllib的詳細內容,更多關于python內置模塊urllib的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲国产精品久久久久 | 男女性高爱潮免费的国产 | 欧美一级毛片欧美大尺度一级毛片 | 97在线播放| 成年人在线免费网站 | 黄色三级三级三级免费看 | 久久手机免费视频 | 久久91亚洲精品久久91综合 | 天天看片天天爽_免费播放 天天看夜夜 | 国产精品国产三级国产在线观看 | 亚洲丝袜另类 | 国产精品欧美一区二区在线看 | 青青热在线精品视频免费 | 精品一区二区三区免费毛片爱 | 欧美一级大片免费看 | 日韩美香港a一级毛片 | 国产精品亚洲欧美日韩一区在线 | 欧美日韩高清在线观看一区二区 | 92国产福利久久青青草原 | 欧美亚洲国产精品久久久久 | 最近中文在线中文 | 国产图片亚洲精品一区 | 国产免费爱在线观看视频 | 国产高清一国产免费软件 | 成人午夜毛片在线看 | 国产高清av在线播放 | 久久91视频 | 成人小视频在线观看 | 成年人黄色片 | 农村寡妇一级毛片免费看视频 | 性理论片 | 欧美激情精品久久久久久久久久 | 成年人午夜免费视频 | 欧美日韩视频在线第一区二区三区 | 久久久久久久久免费影院 | 日本欧美精品 | 精品国产美女福利到在线不卡 | 91精品日本久久久久久牛牛 | 日韩亚洲欧美一区二区三区 | 成人毛片免费视频播放 | 久久久最新精品 |