有没有更好的方法用Python编写这个URL操作?

有没有更好的方法用Python编写这个URL操作?,python,url,parsing,Python,Url,Parsing,我很好奇是否有更简单的方法从url中删除特定参数。我得出的结论如下。这似乎有点冗长。要使用的库或更具Python风格的版本 parsed = urlparse(url) if parsed.query != "": params = dict([s.split("=") for s in parsed.query.split("&")]) if params.get("page"): del params["page"] url = urlunpa

我很好奇是否有更简单的方法从url中删除特定参数。我得出的结论如下。这似乎有点冗长。要使用的库或更具Python风格的版本

parsed = urlparse(url)
if parsed.query != "":
    params = dict([s.split("=") for s in parsed.query.split("&")])
    if params.get("page"):
        del params["page"]
    url = urlunparse((parsed.scheme,
                      None,
                      parsed.path,
                      None,
                      urlencode(params.items()),
                      parsed.fragment,))
    parsed = urlparse(url)
用于破解查询字符串。您可以一次筛选此项:

params = [(k,v) for (k,v) in parse_qsl(parsed.query) if k != 'page']

我创建了一个小型帮助器类,以结构化方式表示url:

import cgi, urllib, urlparse

class Url(object):
    def __init__(self, url):
        """Construct from a string."""
        self.scheme, self.netloc, self.path, self.params, self.query, self.fragment = urlparse.urlparse(url)
        self.args = dict(cgi.parse_qsl(self.query))

    def __str__(self):
        """Turn back into a URL."""
        self.query = urllib.urlencode(self.args)
        return urlparse.urlunparse((self.scheme, self.netloc, self.path, self.params, self.query, self.fragment))
然后你可以做:

u = Url(url)
del u.args['page']
url = str(u)

更多信息:。

即使你做了一点小改动,这里的url操作似乎也很痛苦。@dnolen:我同意。Python的烘焙库对于简单的URI操作不是特别好。(你投了我的反对票吗?如果是的话,因为语言或语言库的限制而投某人的反对票似乎是不合理的。)我投了反对票,因为你的回答没有试图解决实际问题,有些人似乎不这么认为。在任何情况下,14.3k的业力几乎不会影响你;让我恼火的是你认为我没有试图帮你解决问题。标题问题是:“有没有更好的方法用Python编写这个URL操作?”我的回答正好提供了这一点。@bvukelic:没有,但是如果x[0]…,你就必须编写
,这不太清楚。这是一个合理的折衷。远比我想说的有用;)我做了一些,使它更容易使用。