組織のWebサイトの任意のURLと同等のデバッグURLを作成したいと思います。私はこれを行うためのPython関数を持っています:
import urlparse
import urllib
def compose_debug_url(input_url):
input_url_parts = urlparse.urlsplit(input_url)
input_query = input_url_parts.query
input_query_dict = urlparse.parse_qs(input_query)
modified_query_dict = dict(input_query_dict.items() + [('debug', 'sp')])
modified_query = urllib.urlencode(modified_query_dict)
modified_url_parts = (
input_url_parts.scheme,
input_url_parts.netloc,
input_url_parts.path,
modified_query,
input_url_parts.fragment
)
modified_url = urlparse.urlunsplit(modified_url_parts)
return modified_url
print compose_debug_url('http://www.example.com/content/page?name=john&age=35')
print compose_debug_url('http://www.example.com/')
上記のコードを実行すると、次の出力が表示されます。
http://www.example.com/content/page?debug=sp&age=%5B%2735%27%5D&name=%5B%27john%27%5D
http://www.example.com/?debug=sp
代わりに私は期待しています:
http://www.example.com/content/page?debug=sp&age=35&name=john
http://www.example.com/?debug=sp
これurlparse.parse_qs
は、文字列から文字列へのdictではなく、文字列からリストへのdictを返すためです。
Pythonでこれをもっと簡単に行う別の方法はありますか?