from urllib import parse模块的使用
一、介绍
定义了url的标准接口,实现url的各种抽取
parse模块的作用:url的解析,合并,编码,解码
二、代码
实现url的识别和分段
方法1.urlparse
url:待解析的url
scheme='':假如解析的url没有协议,可以设置默认的协议,如果url有协议,设置此参数无效
allow_fragments=True:是否忽略锚点,默认为True表示不忽略,为False表示忽略
复制from urllib import parse
url = 'https://www.cnblogs.com/angelyan/'
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:锚点,用于直接定位页
面的下拉位置,跳转到网页的指定位置
方法2.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
方法3.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
方法4.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)
返回结果:
方法5.quote编码
可以将中文转换为url编码格式
复制tt = time.strftime("%a %b %d %Y %H:%M:%S", time.localtime())
send_time = tt + ' GMT+0800 (中国标准时间)
print(parse.quote(send_time))
url = 'https://www.xinxindai.com/findPassword/sendSMS.html?'+ parse.quote(send_time)+'&mobileNo='+phone+'&imageCode='+code`
print(url)
返回结果:
Sun%20Feb%2007%202021%2016%3A55%3A14%20GMT%2B0800%20%28%E4%B8%AD%E5%9B%BD%E6%A0%87%E5%87%86%E6%97%B6%E9%97%B4%29
https://www.xinxindai.com/findPassword/sendSMS.html?Sun Feb 07 2021 16%3A55%3A14 GMT%2B0800 (中国标准时间)&mobileNo=13811352043&imageCode=9389
方法6.unquote解码
复制from urllib import parse
url = 'https://www.xinxindai.com/findPassword/sendSMS.html?Sun%20Feb%2007%202021%2016%3A55%3A14%20GMT%2B0800%20%28%E4%B8%AD%E5%9B%BD%E6%A0%87%E5%87%86%E6%97%B6%E9%97%B4%29&mobileNo=13811352043&imageCode=9389
'
print(parse.unquote(url)
返回结果:
https://www.xinxindai.com/findPassword/sendSMS.html?Sun Feb 07 2021 15:42:10 GMT+0800 (中国标准时间)&mobileNo=13811352043&imageCode=9389
如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~