url.parse :定义了url的标准接口,实现url的各种抽取
parse模块的使用:url的解析,合并,编码,解码
使用时需导入

from urllib import parse

urlparse()实现URL的识别和分段
url = 'https://book.qidian.com/info/1004608738?wd=123&page=20#Catalog'
"""
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='book.qidian.com', path='/info/1004608738', params='', query='wd=123&page=20', fragment='Catalog')
scheme:表示协议
netloc:域名
path:路径
params:参数
query:查询条件,一般都是get请求的url
fragment:锚点,用于直接定位页
面的下拉位置,跳转到网页的指定位置
"""

urlunparse()可以实现URL的构造

url_parmas = ('https', 'book.qidian.com', '/info/1004608738', '', 'wd=123&page=20', 'Catalog')
#components:是一个可迭代对象,长度必须为6
result = parse.urlunparse(url_parmas)
print(result) """
https://book.qidian.com/info/1004608738?wd=123&page=20#Catalog
""

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

base_url = 'https://book.qidian.com/info/1004608738?wd=123&page=20#Catalog'
sub_url = '/info/100861102' full_url = parse.urljoin(base_url,sub_url) print(full_url)

urlencode()将字典构形式的参数序列化为url编码后的字符串(常用来构造get请求和post请求的参数)k1=v1&k2=v2

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

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. [No000015]坏习惯一大堆?别怕,还有救-坏习惯一堆,怎么好好学习嘛!
  2. weblogic.nodemanager.common.ConfigException: Native version is enabled but nodemanager native library could not be loaded 解决办法
  3. 【总结】IE和Firefox的Javascript兼容性总结(转)
  4. arcgis engine 开发之QI
  5. POJ3283+字典树
  6. C# 网络编程之网页自动登录 (一).使用WebBrower控件模仿登录
  7. ANDROID自己定义视图——onLayout源代码 流程 思路具体解释
  8. ASP.NET MVC中错误处理方式
  9. MySQL逻辑备份into outfile
  10. 整合Spring5+Struts2.5+Hibernate5+maven
  11. Android屏幕相关的概念
  12. Android中使用ViewGroup.removeViews()时出现NullPointException解决方案
  13. SpringBatch 错误积累
  14. WPF手动绑定事件
  15. python 获取字符串中所有数字
  16. [翻译]NUnit---RequiresSTA and RequiresThread Attributes(十七)
  17. java.lang.IncompatibleClassChangeError:可以考虑是否是jar包冲突
  18. post登录趴一趴百度贴吧美女
  19. 【mybatis】在mybatis分页查询时,主表对关联表 一对多 分页查询怎么实现
  20. httpclient 4种关闭连接

热门文章

  1. 将list等分成n份
  2. Java8集合框架——LinkedList源码分析
  3. Navicat Premium 12.0.18 安装与激活
  4. CDH6.2安装配置第二篇:CDH安装的前期配置
  5. Vue框架的介绍及使用
  6. Python笔记_第五篇_Python数据分析基础教程_文件的读写
  7. GFlags 处理内存越界、野指针问题研究
  8. 收藏基本Java项目开发的书
  9. I420转RGB
  10. 爬虫之xpath解析库