1

我正在尝试使用 API。为了测试这一点,我编写了这段代码以获得瑞典国家公共广播电台所有频道的列表,我想打印频道的 ID 和 NAME:

import requests as rq
import json
from pprint import pprint

resp = rq.get('http://api.sr.se/api/v2/channels?
    format=json&indent=TRUE')

respjson = json.loads(resp.text)

pprint (respjson['id'])

我得到了错误

File "sr-api.py", line 9, in <module>
pprint (respjson['id']['name'])
KeyError: 'id'

(缩写)“respjson”看起来像这样

{'channels': [{'channeltype': 'Rikskanal',
           'color': '31a1bd',
           'id': 132,
           'image': 'http://static-cdn.sr.se/sida/images/132/2186745_512_512.jpg?preset=api-default-square',
           'imagetemplate': 'http://static-cdn.sr.se/sida/images/132/2186745_512_512.jpg',
           'liveaudio': {'id': 132,
                         'statkey': '/app/direkt/p1[k(132)]',
                         'url': 'http://sverigesradio.se/topsy/direkt/srapi/132.mp3'},
           'name': 'P1',
           'scheduleurl': 'http://api.sr.se/v2/scheduledepisodes?channelid=132',
           'siteurl': 'http://sverigesradio.se/p1',
           'xmltvid': 'p1.sr.se'},
{'channeltype': 'Lokal kanal',
           'color': 'c31eaa',
           'id': 200,
           'image': 'http://static-cdn.sr.se/sida/images/200/2186775_512_512.jpg?preset=api-default-square',
           'imagetemplate': 'http://static-cdn.sr.se/sida/images/200/2186775_512_512.jpg',
           'liveaudio': {'id': 200,
                         'statkey': '/app/direkt/p4 jämtland[k(200)]',
                         'url': 'http://sverigesradio.se/topsy/direkt/srapi/200.mp3'},
           'name': 'P4 Jämtland',
           'scheduleurl': 'http://api.sr.se/v2/scheduledepisodes?channelid=200',
           'siteurl': 'http://sverigesradio.se/jamtland/',
           'xmltvid': 'p4jmtl.sr.se'}],
'copyright': 'Copyright Sveriges Radio 2017. All rights reserved.',
'pagination': {'nextpage': 'http://api.sr.se/v2/channelsformat=json&indent=true&page=2',
            'page': 1,
            'size': 10,
            'totalhits': 55,
            'totalpages': 6}}
4

2 回答 2

0

您想要做的是查看频道内提供的字典,您可以使用以下内容...

for dic in respjson['channels']:
    pprint(dic['id'])
于 2017-11-01T22:20:57.080 回答
0

频道是一个列表。您必须对其进行迭代以获取所有频道并打印其 ID。

# starting from respjson
respjson = {
    'channels': [
        {
            'channeltype': 'Rikskanal',
            'color': '31a1bd',
            'id': 132,
            'image': 'http://static-cdn.sr.se/sida/images/132/2186745_512_512.jpg?preset=api-default-square',
            'imagetemplate': 'http://static-cdn.sr.se/sida/images/132/2186745_512_512.jpg',
            'liveaudio': {'id': 132,
                          'statkey': '/app/direkt/p1[k(132)]',
                          'url': 'http://sverigesradio.se/topsy/direkt/srapi/132.mp3'},
            'name': 'P1',
            'scheduleurl': 'http://api.sr.se/v2/scheduledepisodes?channelid=132',
            'siteurl': 'http://sverigesradio.se/p1',
            'xmltvid': 'p1.sr.se'},
        {
            'channeltype': 'Lokal kanal',
            'color': 'c31eaa',
            'id': 200,
            'image': 'http://static-cdn.sr.se/sida/images/200/2186775_512_512.jpg?preset=api-default-square',
            'imagetemplate': 'http://static-cdn.sr.se/sida/images/200/2186775_512_512.jpg',
            'liveaudio': {'id': 200,
                          'statkey': '/app/direkt/p4 jämtland[k(200)]',
                          'url': 'http://sverigesradio.se/topsy/direkt/srapi/200.mp3'},
            'name': 'P4 Jämtland',
            'scheduleurl': 'http://api.sr.se/v2/scheduledepisodes?channelid=200',
            'siteurl': 'http://sverigesradio.se/jamtland/',
            'xmltvid': 'p4jmtl.sr.se'
        }
    ],
    'copyright': 'Copyright Sveriges Radio 2017. All rights reserved.',
    'pagination': {
        'nextpage': 'http://api.sr.se/v2/channelsformat=json&indent=true&page=2',
        'page': 1,
        'size': 10,
        'totalhits': 55,
        'totalpages': 6
    }
}

for channel in respjson['channels']:
    print(channel['id'])
于 2017-11-01T22:26:25.453 回答