继续学习python的web模块,urlparse 是一个比较简单的模块,主要是用来 解析URL字符串的
1 urlparse简介
python使用urlparse来解析URL字符串
主要方法: urlprase
次要方法: urljoin urlsplit urlunsplit等
2 urlparse详解
urlparse模块主要是把url拆分为6部分,并返回元组。并且可以把拆分后的部分再组成一个url。主要有函数有urljoin、urlsplit、urlunsplit、urlparse等。
URL格式包含:
协议://用户名@密码:子域名.域名.顶级域名:端口/目录/文件名.文件后缀?参数=值#标志
2.1 urlparse
urlparse.urlparse(urlstring[,scheme[, allow_fragments]]) 可选参数: scheme �C 主要是用来 为不包含些一部分的URL指定默认协议,此参数的默认值为空字符串 allow_fragments 用来指示是否可以对地址进行分片,此参数的默认值为 True
将urlstring解析成6个部分,它从urlstring中取得URL,并返回元组 (scheme, netloc, path, parameters,query, fragment),但是实际上是基于namedtuple,是tuple的子类。它支持通过名字属性或者索引访问的部分URL,每个组件是一串字符,也有可能是空的。组件不能被解析为更小的部分,%后面的也不会被解析,分割符号并不是解析结果的一部分,除非用斜线转义,注意,返回的这个元组非常有用,例如可以用来确定网络协议(HTTP、FTP等等 )、服务器地址、文件路径,等等。
urlparse方法返回对象中的属性:
属性 |
索引值 | 值含义 | 默认值 | 备注 |
scheme | 0 | 协议 | 空字符串 |
|
netloc | 1 | 服务器地址 | 空字符串 | |
path | 2 | 路径 | 空字符串 | |
parameters | 3 | 参数 | 空字符串 | |
query | 4 | 查询部分 | 空字符串 | |
fragment | 5 | 分片部分 | 空字符串 | |
username | 用户名 | None | ||
password | 密码 | None | ||
hostname | 主机名 | None | ||
port | 端口 | None |
附代码:
>>> import urlparse >>> url=urlparse.urlparse('http://www.baidu.com/index.php?username=51cto') >>> url ParseResult(scheme='http',netloc='www.baidu.com', path='/index.php', params='', query='username=51cto ', fragment='') >>> url.scheme 'http' >>> url.netloc 'www.baidu.com' >>> url.path '/index.php' >>> url.params '' >>> url.query 'username=51cto' >>> url.fragment '' >>> url.geturl() 'http://www.baidu.com/index.php?username=51cto' >>> url ParseResult(scheme='http', netloc='', path='www.baidu.com/index.php',params='', query='username=51cto ', fragment='') #备注:当URL 中不存在 http的时候,会自动使用此参数
2.2 urljoin
urlparse.urljoin(base,url[, allow_fragments])
urljoin主要是拼接URL,它以base作为其基地址,然后与url中的相对地址相结合组成一个绝对URL地址。函数urljoin在通过为URL基地址附加新的文件名的方式来处理同一位置处的若干文件的时候格外有用。需要注意的是,如果基地址并非以字符/结尾的话,那么URL基地址最右边部分就会被这个相对路径所替换。如果希望在该路径中保留末端目录,应确保URL基地址以字符/结尾。
附代码:
>>>url=urlparse.urljoin('http://www.baidu.com','index.html') >>> url 'http://www.baidu.com/index.html'
由于对输入的参数没有限制,所以需要注意:
2.2.1 当输入的参数都是空字符串的时候,返回的拼合url也是空字符串
附代码:
>>> url = urlparse.urljoin('','') >>> url ''
2.2.2 在相对url中如果有协议字段,则优先使用相对url中的协议,否则使用绝对url中的协议字段
附代码:
>>> url = urlparse.urljoin('http://www.baidu.com','ftp://www.baidu.com/index.html') >>> url 'ftp://www.baidu.com/index.html' >>> url = urlparse.urljoin('http://www.baidu.com','www.baidu.com/index.html') >>> url 'http://www.baidu.com/www.baidu.com/index.html'
当相对字符串中不包含协议的时候,就会将所有的字符串认为是一个路径信息,从而忙字符串的值和绝对url的值结合了起来
2.2.3 当绝对url和相对url中都含有服务器地址且不相同的时候,将采用相对url地址的服务器地址和路径
附代码:
>>> url = urlparse.urljoin('http://www.baidu.com','http://www.baidu.com/index.html') >>> url 'http://www.baidu.com/index.html'
2.3 urlsplit
urlparse.urlsplit(urlstring[,scheme[, allow_fragments]])
主要是分析urlstring,返回一个包含5个字符串项目的元组:协议、位置、路径、查询、片段。allow_fragments为False时,该元组的组后一个项目总是空,不管urlstring有没有片段,省略项目的也是空。urlsplit()和urlparse()差不多。不过它不切分URL的参数。适用于遵循RFC2396的URL,每个路径段都支持参数。这样返回的元组就只有5个元素。
附代码:
>>> url = urlparse.urlsplit('http://www.baidu.com:80/index.html?src=fie') >>> url SplitResult(scheme='http',netloc='www.baidu.com:80', path='/index.html', query='src=fie', fragment='') >>> url = urlparse.urlparse('http://www.baidu.com:80/index.html?src=fie') >>> url ParseResult(scheme='http',netloc='www.baidu.com:80', path='/index.html', params='', query='src=fie',fragment='')
2.4 urlunsplit
urlparse.urlunsplit(parts)
urlunsplit使用urlsplit()返回的值组合成一个url
附代码:
>>> url = urlparse.urlsplit('http://www.baidu.com:80/index.html?src=fie') >>> url SplitResult(scheme='http',netloc='www.baidu.com:80', path='/index.html', query='src=fie', fragment='') >>> url=urlparse.urlunsplit(('http','www.baidu.com:80','/index.html','src=fie','')) >>> url 'http://www.baidu.com:80/index.html?src=fie'
2.4 urlunparse
urlparse.urlunparse(parts)
从一个元组构建一个url,元组类似urlparse返回的,它接收元组(scheme, netloc, path, parameters, query, fragment)后,会重新组成一个具有正确格式的URL,以便供Python的其他HTML解析模块使用。
>>> url =urlparse.urlparse('http://www.baidu.com:80/index.html?src=fie') >>> url ParseResult(scheme='http', netloc='www.baidu.com:80',path='/index.html', params='', query='src=fie', fragment='') >>> url = urlparse.urlunparse(url) >>> url 'http://www.baidu.com:80/index.html?src=fie'
未完,待续。。。