一、介绍

定义了url的标准接口,实现url的各种抽取

parse模块的作用:url的解析,合并,编码,解码

二、代码

方法一:urlparse

实现url的识别和分段

from urllib import parse

url = 'https://www.cnblogs.com/angelyan/'
"""
url:待解析的url
scheme='':假如解析的url没有协议,可以设置默认的协议,如果url有协议,设置此参数无效
allow_fragments=True:是否忽略锚点,默认为True表示不忽略,为False表示忽略
"""
result = parse.urlparse(url=url,scheme='http',allow_fragments=True) print(result)
print(result.scheme)
"""
(scheme='https', netloc='www.cnblogs.com', path='/angelyan/', params='', query='', fragment='')
scheme:表示协议
netloc:域名
path:路径
params:参数
query:查询条件,一般都是get请求的url
fragment:锚点,用于直接定位页
面的下拉位置,跳转到网页的指定位置
"""

方法二:urlunparse

可以实现url的构造

url_parmas = ('https', 'www.cnblogs.com', '/angelyan/', '', 'name=maple', 'log')
#components:是一个可迭代对象,长度必须为6
result = parse.urlunparse(url_parmas)
print(result) """
https://www.cnblogs.com/angelyan/?name=maple#log
"""

方法三:urljoin

传递一个基础连接,根据基础连接可以将某一个不完整的链接拼接为一个完整链接

base_url = 'https://www.cnblogs.com'
sub_url = '/angelyan/?name=maple#log' full_url = parse.urljoin(base_url,sub_url) print(full_url)
"""
https://www.cnblogs.com/angelyan/?name=maple#log
"""

方法四:urlencode

将字典形式的参数序列化为url编码后的字符串,常用来构造get请求和post请求的参数

parmas = {
'name':'maple',
'age':18
}
parmas_str = parse.urlencode(parmas)
print(parmas_str)
"""
name=maple&age=18
"""
parmas_str = 'name=maple&age=18'
# 将url编码格式的参数反序列化为字典类型
parmas = parse.parse_qs(parmas_str)
print(parmas) """
{'name': ['maple'], 'age': ['18']}
"""

方法五:quote

可以将中文转换为url编码格式

word = '中国梦'
url = 'http://www.baidu.com/s?wd='+parse.quote(word)
print(parse.quote(word))
print(url) """
%E4%B8%AD%E5%9B%BD%E6%A2%A6
http://www.baidu.com/s?wd=%E4%B8%AD%E5%9B%BD%E6%A2%A6
"""
# unquote:可以将URL编码进行解码
url = 'http://www.baidu.com/s?wd=%E4%B8%AD%E5%9B%BD%E6%A2%A6'
print(parse.unquote(url))
"""
http://www.baidu.com/s?wd=中国梦
"""

最新文章

  1. java移位运算符
  2. mysql CREATE USER
  3. 【BZOJ】1124: [POI2008]枪战Maf
  4. 测试nfs和cifs
  5. iOS多线程编程指南(二)线程管理
  6. parallels无法启动之大乌龙-流水账版
  7. android开发中R文件丢失
  8. 病毒侵袭 - HDU 2896(AC自动机)
  9. CSS3实现Tooltip提示框飞入飞出动画
  10. 连接linux 服务器
  11. [2015-11-23]分享一个批处理脚本,创建iis站点及程序池
  12. case
  13. Django模型层之字段查询参数及聚合函数
  14. [LeetCode] Smallest Subtree with all the Deepest Nodes 包含最深结点的最小子树
  15. Asp.net Core 项目中如何使用 MongoDB 数据库
  16. 【C++ 继承与派生/知识梳理】
  17. 7.1 C++模板基本概念及语法 《C++模板与标准模板库》
  18. git and github问题集锦
  19. (最小生成树) 畅通工程再续 -- HDU --1875
  20. springmvc IDEA

热门文章

  1. Pregel Master
  2. 简单三层BP神经网络学习算法的推导
  3. 5. java运算符
  4. Python自学:第四章 遍历切片
  5. on windows in superset sql lab error "module object has no attribute sigalrm"
  6. 任意两点间的最短路问题(Floyd-Warshall算法)
  7. OpenGL ANYTOOL
  8. 【SQL】ON DUPLICATE KEY UPDATE
  9. 二分图hall定理应用+二分+双指针——cf981F(好题)
  10. 理解MITRE ATT&CK矩阵