本文介绍了python中urllib模块的用法,Python urllib模块用于URL编码解码功能的例子,urllib的一些其它很有用的辅助方法,比如对 url 进行编码、解码等,需要的朋友参考下。
在之前的文章中介绍了python urllib 模块的用法,以及它常用的 urlopen() 和 urlretrieve()函数用法,并分析了python模块urllib2与urllib的区别。
当然 urllib 还有一些其它很有用的辅助方法,比如对 url 进行编码、解码等。
url 中是不能出现一些特殊的符号的,有些符号有特殊的用途。比如以 get 方式提交数据的时候,会在 url 中添加 key=value 这样的字符串,所以在 value 中是不允许有 '=',因此要对其进行编码;与此同时服务器接收到这些参数的时候,要进行解码,还原成原始的数据。
此时这些辅助方法会很有用:
urllib.quote(string[, safe]):对字符串进行编码。参数 safe 指定了不需要编码的字符;
urllib.unquote(string) :对字符串进行解码;
urllib.quote_plus(string [ , safe ] ) :与 urllib.quote 类似,但这个方法用'+'来替换' ',而 quote 用'%20'来代替' '
urllib.unquote_plus(string ) :对字符串进行解码;
urllib.urlencode(query[, doseq]):将dict或者包含两个元素的元组列表转换成url参数。例如 字典{'name': 'dark-bull', 'age': 200}将被转换为"name=dark-bull&age=200"
urllib.pathname2url(path):将本地路径转换成 url 路径;
urllib.url2pathname(path):将url路径转换成本地路径;
例子,python urllib模块的Url编码解码功能。
复制代码 代码示例:
import urllib
data = 'name = ~nowamagic+5'
data1 = urllib.quote(data)
print data1 # result: name%20%3D%20%7Enowamagic%2B5
print urllib.unquote(data1) # name = ~nowamagic+5
data2 = urllib.quote_plus(data)
print data2 # result: name+%3D+%7Enowamagic%2B5
print urllib.unquote_plus(data2) # name = ~nowamagic+5
data3 = urllib.urlencode({ 'name': 'nowamagic-gonn', 'age': 200 })
print data3 # result: age=200&name=nowamagic-gonn
data4 = urllib.pathname2url(r'd:/a/b/c/23.php')
print data4 # result: ///D://a/b/c/23.php
print urllib.url2pathname(data4) # result: D:/a/b/c/23.php
在 Python Shell 里执行的具体情况为:
复制代码 代码示例:
Python 2.7.5 (default, May 15 2013, 22:44:16) [MSC v.1500 64 bit (AMD64)] on win32
Type "copyright", "credits" or "license()" for more information.
>>> import urllib
>>> data = 'name = ~nowamagic+5'
>>> data1 = urllib.quote(data)
>>> print data1
name%20%3D%20%7Enowamagic%2B5
>>> print urllib.unquote(data1)
name = ~nowamagic+5
>>> data2 = urllib.quote_plus(data)
>>> print data2
name+%3D+%7Enowamagic%2B5
>>> print urllib.unquote_plus(data2)
name = ~nowamagic+5
>>> data3 = urllib.urlencode({ 'name': 'nowamagic-gonn', 'age': 200 })
>>> print data3
age=200&name=nowamagic-gonn
>>> data4 = urllib.pathname2url(r'd:/a/b/c/23.php')
>>> print data4
///D://a/b/c/23.php
>>> print urllib.url2pathname(data4)
D:\a\b\c\23.php
urllib 模块的基本使用也比较简单,大家可以深入研究下。