在Python 2.4中使用urllib解析查询字符串
我在用Python2.4.5(别问我为什么用这个版本!),我想解析一个查询字符串,然后得到一个字典(dict)。请问我是不是得像下面这样“手动”去做呢?
>>> qs = 'first=1&second=4&third=3'
>>> d = dict([x.split("=") for x in qs.split("&")])
>>> d
{'second': '4', 'third': '3', 'first': '1'}
我在urlparse
里没找到任何有用的方法。
3 个回答
1
在编程中,有时候我们需要处理一些数据,比如从一个地方获取数据,然后在程序里使用这些数据。这个过程就像是从冰箱里拿食材,然后用这些食材做饭一样。
有些时候,我们需要把这些数据放到一个特定的格式里,这样程序才能理解。就像把食材切成合适的大小,才能更好地烹饪。
在这个过程中,可能会遇到一些问题,比如数据格式不对,或者数据缺失。这就像在做饭时发现缺少某种调料一样,需要想办法解决。
总之,处理数据就像做饭,需要准备、整理和解决问题,才能做出美味的菜肴。
import urlparse
qs = 'first=1&second=4&third=3&first=0'
print dict(urlparse.parse_qsl(qs))
OR
print urlparse.parse_qs(qs)
9
这解决了一个让人烦恼的问题:
d = dict(urlparse.parse_qsl( qs ) )
我个人觉得,urlparse里应该有一个内置的包装器。在大多数情况下,如果有多余的参数,我也不介意把它们丢掉。
23
你有两个选择:
>>> cgi.parse_qs(qs)
{'second': ['4'], 'third': ['3'], 'first': ['1']}
或者
>>> cgi.parse_qsl(qs)
[('first', '1'), ('second', '4'), ('third', '3')]
通过 cgi.parse_qs()
返回的字典里的值是列表,而不是字符串。这是为了处理同一个参数被多次指定的情况:
>>> qs = 'tags=python&tags=programming'
>>> cgi.parse_qs(qs)
{'tags': ['python', 'programming']}