>>> urllib.quote_plus(u'江南小财主')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.5/urllib.py", line 1213, in quote_plus
return quote(s, safe)
File "/usr/lib/python2.5/urllib.py", line 1205, in quote
res = map(safe_map.__getitem__, s)
KeyError: u'\u6c5f'
因为从数据库里取出来的字符串是unicode。 但是quote_plus函数只接受ascii码, 所以需要先把字符串encode一下。
>>> urllib.quote_plus(u'江南小财主'.encode('utf8'))
'%E6%B1%9F%E5%8D%97%E5%B0%8F%E8%B4%A2%E4%B8%BB'
本文介绍如何将从数据库中获取的Unicode字符串转换为适用于URL的参数。由于直接使用Unicode字符串作为URL参数会导致错误,文章提供了正确的编码方法:先将字符串转换为UTF-8编码,再使用urllib.quote_plus进行编码。
2332

被折叠的 条评论
为什么被折叠?



