如何在Python中获得多维字典的URL编码版本?不幸的是,urllib.urlencode()只能在一个维度上工作。我需要一个能够递归编码字典的版本。
例如,如果我有以下字典:
{'a': 'b', 'c': {'d': 'e'}}我想要获取以下字符串:
a=b&c[d]=e发布于 2010-10-25 19:38:12
好了,各位。我自己实现的:
import urllib
def recursive_urlencode(d):
"""URL-encode a multidimensional dictionary.
>>> data = {'a': 'b&c', 'd': {'e': {'f&g': 'h*i'}}, 'j': 'k'}
>>> recursive_urlencode(data)
u'a=b%26c&j=k&d[e][f%26g]=h%2Ai'
"""
def recursion(d, base=[]):
pairs = []
for key, value in d.items():
new_base = base + [key]
if hasattr(value, 'values'):
pairs += recursion(value, new_base)
else:
new_pair = None
if len(new_base) > 1:
first = urllib.quote(new_base.pop(0))
rest = map(lambda x: urllib.quote(x), new_base)
new_pair = "%s[%s]=%s" % (first, ']['.join(rest), urllib.quote(unicode(value)))
else:
new_pair = "%s=%s" % (urllib.quote(unicode(key)), urllib.quote(unicode(value)))
pairs.append(new_pair)
return pairs
return '&'.join(recursion(d))
if __name__ == "__main__":
import doctest
doctest.testmod()不过,我还是很有兴趣知道是否有更好的方法来做这件事。我不敢相信Python的标准库没有实现这一点。
https://stackoverflow.com/questions/4013838
复制相似问题