JSONオブジェクトを反復処理して、データ、つまりタイトルとリンクをインポートしようとしています。 :
を過ぎたコンテンツにアクセスできないようです。
JSON:
[
{
"title": "Baby (Feat. Ludacris) - Justin Bieber",
"description": "Baby (Feat. Ludacris) by Justin Bieber on Grooveshark",
"link": "http://listen.grooveshark.com/s/Baby+Feat+Ludacris+/2Bqvdq",
"pubDate": "Wed, 28 Apr 2010 02:37:53 -0400",
"pubTime": 1272436673,
"TinyLink": "http://tinysong.com/d3wI",
"SongID": "24447862",
"SongName": "Baby (Feat. Ludacris)",
"ArtistID": "1118876",
"ArtistName": "Justin Bieber",
"AlbumID": "4104002",
"AlbumName": "My World (Part II);\nhttp://tinysong.com/gQsw",
"LongLink": "11578982",
"GroovesharkLink": "11578982",
"Link": "http://tinysong.com/d3wI"
},
{
"title": "Feel Good Inc - Gorillaz",
"description": "Feel Good Inc by Gorillaz on Grooveshark",
"link": "http://listen.grooveshark.com/s/Feel+Good+Inc/1UksmI",
"pubDate": "Wed, 28 Apr 2010 02:25:30 -0400",
"pubTime": 1272435930
}
]
辞書を使ってみました:
def getLastSong(user,limit):
base_url = 'http://gsuser.com/lastSong/'
user_url = base_url + str(user) + '/' + str(limit) + "/"
raw = urllib.urlopen(user_url)
json_raw= raw.readlines()
json_object = json.loads(json_raw[0])
#filtering and making it look good.
gsongs = []
print json_object
for song in json_object[0]:
print song
このコードは、:
の前の情報のみを出力します。 (ジャスティン・ビーバーのトラックを無視する:))
JSONデータのロードは少し脆弱です。の代わりに:
json_raw= raw.readlines()
json_object = json.loads(json_raw[0])
あなたは本当にやるべきです:
json_object = json.load(raw)
あなたが「JSONオブジェクト」として得るものを考えるべきではありません。あなたが持っているのはリストです。リストには2つの辞書が含まれています。 dictには、すべての文字列であるさまざまなキー/値のペアが含まれています。 json_object[0]
を実行すると、リストの最初の辞書が必要になります。 for song in json_object[0]:
を使用してそれを反復すると、dictのキーを反復します。それは、辞書を反復処理するときに得られるものだからです。その辞書のキーに関連付けられた値にアクセスする場合は、たとえばjson_object[0][song]
を使用します。
これはJSONに固有のものではありません。これは基本的なPythonタイプであり、基本的な操作はチュートリアルで説明されています。
私はあなたがおそらく意味していたと思う:
for song in json_object:
# now song is a dictionary
for attribute, value in song.iteritems():
print attribute, value # example usage
注意:Pythonにはsong.items
の代わりにsong.iteritems
を使用してください3。
この質問は長い間ここにありましたが、私は通常、JSONオブジェクトを反復処理する方法を提供したいと考えました。以下の例では、JSONを含むハードコードされた文字列を示しましたが、JSON文字列はWebサービスまたはファイルから簡単に取得できます。
import json
def main():
# create a simple JSON array
jsonString = '{"key1":"value1","key2":"value2","key3":"value3"}'
# change the JSON string into a JSON object
jsonObject = json.loads(jsonString)
# print the keys and values
for key in jsonObject:
value = jsonObject[key]
print("The key and value are ({}) = ({})".format(key, value))
pass
if __== '__main__':
main()
JSONを逆シリアル化すると、pythonオブジェクトが作成されます。通常のオブジェクトメソッドを使用します。
この場合、辞書で作成されたリストがあります:
json_object[0].items()
json_object[0]["title"]
等.
私はこの問題をもっとこのように解決します
import json
import urllib2
def last_song(user, limit):
# Assembling strings with "foo" + str(bar) + "baz" + ... generally isn't
# as Nice as using real string formatting. It can seem simpler at first,
# but leaves you less happy in the long run.
url = 'http://gsuser.com/lastSong/%s/%d/' % (user, limit)
# urllib.urlopen is deprecated in favour of urllib2.urlopen
site = urllib2.urlopen(url)
# The json module has a function load for loading from file-like objects,
# like the one you get from `urllib2.urlopen`. You don't need to turn
# your data into a string and use loads and you definitely don't need to
# use readlines or readline (there is seldom if ever reason to use a
# file-like object's readline(s) methods.)
songs = json.load(site)
# I don't know why "lastSong" stuff returns something like this, but
# your json thing was a JSON array of two JSON objects. This will
# deserialise as a list of two dicts, with each item representing
# each of those two songs.
#
# Since each of the songs is represented by a dict, it will iterate
# over its keys (like any other Python dict).
baby, feel_good = songs
# Rather than printing in a function, it's usually better to
# return the string then let the caller do whatever with it.
# You said you wanted to make the output pretty but you didn't
# mention *how*, so here's an example of a prettyish representation
# from the song information given.
return "%(SongName)s by %(ArtistName)s - listen at %(link)s" % baby
Python 3の場合、Webサーバーから取得したデータをデコードする必要があります。たとえば、データをutf8としてデコードしてから処理します。
# example of json data object group with two values of key id
jsonstufftest = '{'group':{'id':'2','id':'3'}}
# always set your headers
headers = {'User-Agent': 'Moz & Woz'}
# the url you are trying to load and get json from
url = 'http://www.cooljson.com/cooljson.json'
# in python 3 you can build the request using request.Request
req = urllib.request.Request(url,None,headers)
# try to connect or fail gracefully
try:
response = urllib.request.urlopen(req) # new python 3 code -jc
except:
exit('could not load page, check connection')
# read the response and DECODE
html=response.read().decode('utf8') # new python3 code
# now convert the decoded string into real JSON
loadedjson = json.loads(html)
# print to make sure it worked
print (loadedjson) # works like a charm
# iterate through each key value
for testdata in loadedjson['group']:
print (accesscount['id']) # should print 2 then 3 if using test json
デコードしない場合、Python 3でバイトエラーと文字列エラーが発生します。
jSONを反復処理するには、これを使用できます。
json_object = json.loads(json_file)
for element in json_object:
for value in json_object['Name_OF_YOUR_KEY/ELEMENT']:
print(json_object['Name_OF_YOUR_KEY/ELEMENT']['INDEX_OF_VALUE']['VALUE'])