質問

APIから座標を取得しようとしていますが、JSONオブジェクトの1つにデンマーク文字が含まれているため、エラーが発生し続けます。これが私が持っているものです:

# -*- coding: utf-8 -*-
import urllib2
import json
import codecs

url='http://geo.oiorest.dk/adresser.json?postnr=1577&vejnavn=bernstorffsgade&husnr=16'

addressline = "%s, %s"

try:
    data = urllib2.urlopen(url).read().decode('utf-8')
    adresser = json.loads(data, encoding='utf-8')

    for adresse in adresser:
        print addressline % \
            (adresse['etrs89koordinat']['øst'],
             adresse['etrs89koordinat']['nord'])

except urllib2.HTTPError, e:
    print "HTTP error: %d" % e.code
except urllib2.URLError, e:
    print "Network error: %s" % e.reason.args[1]
.

私が得るエラー:

KeyError: '\xc3\xb8st'
.

役に立ちましたか?

解決

復号化データにはUnicode文字列が含まれているため、Unicode文字列を使用して物事を調べる必要があります。

print addressline % \
    (adresse[u'etrs89koordinat'][u'øst'],
     adresse[u'etrs89koordinat'][u'nord'])
.

(Unicode文字列を使用するかどうかにかかわらず、Unicode文字列を使用するかどうかにかかわる文字列には機能する可能性があります。>

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top