Transform unicode-string in python
{u'Status': u'OK', u'City': u'Ciri\xe8', u'TimezoneName': '', u'ZipPostalCode': '', u'CountryCode': u'IT', u'Dstoffset': u'0', u'Ip': u'x.x.x.x', u'Longitude': u'7.6', u'CountryName': u'Italy', u'RegionCode': u'12', u'Latitude': u'45.2333', u'Isdst': '', u'Gmtoffset': u'0', u'RegionName': u'Piemonte'}
Dies ist die Ausgabe von meinem Objekt. Ich möchte access City aber Es ist codiert. Wie kann ich Lesen Sie alle Parameter und decodieren
>>> data['City']
u'Ciri\xe8'
>>>data['City'].decode('utf-8')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/encodings/utf_8.py", line 16, in decode
return codecs.utf_8_decode(input, errors, True)
UnicodeEncodeError: 'ascii' codec can't encode character u'\xe8' in position 4: ordinal not in range(128)
Ich will Klartext, keine unicode-string. Danke!
Ich bin mit diesem code github.com/sonicrules1234/pyipinfodb/blob/master/pyipinfodb.py
Es gibt keine solche Sache wie "Klartext".
Sie nicht haben, etwas zu tun. Es ist bereits dekodiert... Versuchen
Wie Sie sehen in der post das Ergebnis der zu druckenden Daten['Stadt'] ist u'Ciri\xe8'
Nein, den Sie gerade eingegeben haben
Es gibt keine solche Sache wie "Klartext".
Sie nicht haben, etwas zu tun. Es ist bereits dekodiert... Versuchen
print data['City']
Wie Sie sehen in der post das Ergebnis der zu druckenden Daten['Stadt'] ist u'Ciri\xe8'
Nein, den Sie gerade eingegeben haben
data['City']
. Versuchen print data['City']
. Für mich, in iPython, das macht einen Unterschied.InformationsquelleAutor dani | 2012-04-22
Du musst angemeldet sein, um einen Kommentar abzugeben.
Lesen: http://nedbatchelder.com/text/unipain.html
Dann einfach ausdrucken:
Wenn Sie nicht drucken, Python-prints eine sichere Darstellung der Zeichenfolge, die angibt, es ist Unicode-text
u''
, und es enthält einen nicht-ASCII-Zeichen\xe8
.print
versuche zur Darstellung der nicht-ASCII-Zeichen durch die Kodierung der Unicode-string in das terminal-encoding. Es kann fehlschlagen, wenn die Zeichenfolge Zeichen enthält, die nicht unterstützt werden, indem der terminal-encoding:Im obigen Beispiel, code page 437 unterstützt Unicode-Zeichen U+00E8, aber nicht U+0081.
InformationsquelleAutor Mark Tolonen
Was Sie wollen, ist nicht klar. Wenn man mit 'Klartext', Sie bedeuten, zu entfernen Akzentuierung, versuchen Sie dies:
InformationsquelleAutor Pedro Werneck
Durch Klartext, ich nehme an, du meinst ascii. Für diese können Sie verwenden:
dieser Streifen das unicode-Zeichen und return
Finden Sie unter diesem link für mehr Informationen: http://docs.python.org/howto/unicode.html
InformationsquelleAutor Jeff Wu