urllib.urlencode
İşlendikten sonra verileri nasıl dikteye dönüştürebilirim ?
urllib.urldecode
mevcut değil.
Yanıtlar:
Gibi dokümanlar için urlencode
söz hakkından,
Urlparse modülü, sorgu dizelerini Python veri yapılarına ayrıştırmak için kullanılan parse_qs () ve parse_qsl () işlevlerini sağlar.
(Eski Python sürümlerinde cgi
modülün içindeydiler ). Yani mesela:
>>> import urllib
>>> import urlparse
>>> d = {'a':'b', 'c':'d'}
>>> s = urllib.urlencode(d)
>>> s
'a=b&c=d'
>>> d1 = urlparse.parse_qs(s)
>>> d1
{'a': ['b'], 'c': ['d']}
Orijinal sözlük d
ile "gidiş geliş" arasındaki bariz fark d1
, ikincisinin (bu durumda tek öğeli) listelere sahip olmasıdır - bunun nedeni, sorgu dizelerinde benzersizlik garantisi olmaması ve önemli olabilir. uygulamanıza her anahtar için hangi birden çok değerin verildiğini bilmek için (yani, listeler her zaman tek öğeli olanlar olmayacaktır ;-).
Alternatif olarak:
>>> sq = urlparse.parse_qsl(s)
>>> sq
[('a', 'b'), ('c', 'd')]
>>> dict(sq)
{'a': 'b', 'c': 'd'}
bir çift dizisi elde edebilirsiniz (urlencode böyle bir argümanı da kabul eder - bu durumda sırayı korurken, dikte durumunda ;-) korunacak bir sıra yoktur. Yinelenen "anahtarlar" olmadığını biliyorsanız veya varsa, umursamıyorsanız, o zaman (gösterdiğim gibi) dict
liste dışı değerler içeren bir sözlük almak için arayabilirsiniz . Genel olarak, ancak, çiftleri eğer ne yapmak istediğinizi düşünün gereğini yapmak vardır (Python sizin adınıza ;-) o karar vermez mevcut.
urllib
modülün içinde. @Phobie cevabına bakın.
Alex'in çözümü için Python 3 kodu :
>>> import urllib.parse
>>> d = {'a':'b', 'c':'d'}
>>> s = urllib.parse.urlencode(d)
>>> s
'a=b&c=d'
>>> d1 = urllib.parse.parse_qs(s)
>>> d1
{'a': ['b'], 'c': ['d']}
Alternatif:
>>> sq = urllib.parse.parse_qsl(s)
>>> sq
[('a', 'b'), ('c', 'd')]
>>> dict(sq)
{'a': 'b', 'c': 'd'}
parse_qsl tersine çevrilebilir:
>>> urllib.parse.urlencode(sq)
'a=b&c=d'
urllib.unquote_plus()
ne istersen yapar. % Xx çıkışlarını tek karakterlik eşdeğerleriyle değiştirir ve artı işaretlerini boşluklarla değiştirir.
Misal:
unquote_plus('/%7Ecandidates/?name=john+connolly')
verim
'/~candidates/?name=john connolly'.