在Python 2.4中使用urllib解析查询字符串

12 投票
3 回答
12046 浏览
提问于 2025-04-15 16:12

我在用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']}

撰写回答