используя клиент pytumblr, я получаю этот тип вывода
{
"total_blogs": 2,
"blogs": [
{
"name": "testblog",
"title": "testblog",
"description": "A testblog",
"url": "https://testblog.tumblr.com/",
"uuid": "t:g8wqt6wBUe3AJkJXYHn1",
"updated": 1526680515
},
{
"name": "testblog1",
"title": "testblog1",
"description": "A testblog1",
"url": "https://testblog1.tumblr.com/",
"uuid": "t:qwuedBBFIPMTViKhjozp",
"updated": 1510382395
}],
"_links": {
"next": {
"href": "/v2/user/following?offset=20",
"method": "GET",
"query_params": {
"offset": "20"
}
}
}
} }
Я могу просто распечатать значения total_blogs и blogs, но у меня проблемы с доступом к внутренним значениям, в частности к URL-адресу, и я не смог применить руководства или некоторые другие примеры, которые я видел здесь в способ, который поможет с этой проблемой.
Конечная игра в основном заключается в том, чтобы иметь возможность зацикливать программу, пока я не получу все значения URL-адресов. Я могу получить доступ только к 20 блогам за раз, так что сколько значений url мне нужно будет получить
Доступ к массиву json в Python без ссылки на его имя
ответ на этой странице, казалось, был решением, но попытка применить его к моему коду
for anything in usrFollowing:
if isinstance(usrFollowing[anything], list):
for values in usrFollowing[anything]:
print(values['blogs']['name'])
просто дает мне KeyError: 'blogs' из последней строки. я не уверен, что еще я могу сделать на данный момент
у меня есть дополнительная проблема - выяснить, как вывести код в более читаемый формат. на консоли веб-сайта tumblr он выводит как исходный код, который я показал выше, но все, что я получаю, - это просто текущая строчная печать на консоль. есть ли способ изменить это?
client = pytumblr.TumblrRestClient()
userFollowing = client.Following()
- это то, что вы имеете в виду @NikolajBaer
Теперь я понимаю, что смотрел на сторону JSON, но не на его питонную часть.
Если вы можете десериализовать из JSON в структуры данных Python, тогда у вас есть данные Python, а не данные JSON - JSON больше не является важной частью вопроса после успешной десериализации. (То есть: ваша проблема была бы так же применима, если бы вам была передана структура данных Python в качестве входных данных с той же формой, вместо того, чтобы иметь JSON в первую очередь).
Это должно получить URL-адреса блога, за которыми следует ваш tumblr:
import pytumblr
client = pytumblr.TumblrRestClient(...) # replace ... with your credentials
usrFollowing = client.following()
for blog in usrFollowing['blogs']:
print(blog['url'])
Я думаю, что можно понять эту структуру по частям.
usrFollowing
var - это словарь
...
usrFollowing = client.following()
for key in usrFollowing.keys():
print(key)
# outputs:
# blogs
# _links
# total_blogs
Итак, чтобы получить доступ к каждому блогу, мы можем перебирать их, используя ключ blogs
:
...
usrFollowing = client.following()
for blog in usrFollowing['blogs']:
print(blog)
# outputs something like:
# {u'updated': 1539793245, u'uuid': u't:CwoihvyyOxn8Mk5TUS0KDg', u'title': u'Tumblr Engineering', u'url': u'https://engineering.tumblr.com/', u'name': u'engineering', u'description': u'Dispatches from the intrepid tinkerers behind technology at Tumblr.'}
# {u'updated': 1545058816, u'uuid': u't:0aY0xL2Fi1OFJg4YxpmegQ', u'title': u'Tumblr Staff', u'url': u'https://staff.tumblr.com/', u'name': u'staff', u'description': u''}
Есть несколько способов вывести объекты в более «человеческом» формате, использовать pprint
или преобразовать объект в JSON, указав величину отступа:
...
import pprint
import json
print('Python pretty-printed')
for blog in usrFollowing['blogs']:
pprint.pprint(blog)
print('')
print('JSON pretty-printed')
for blog in usrFollowing['blogs']:
print(json.dumps(blog, indent=2))
# outputs something like:
# Python pretty-printed
# {u'description': u'Dispatches from the intrepid tinkerers behind technology at Tumblr.',
# u'name': u'engineering',
# u'title': u'Tumblr Engineering',
# u'updated': 1539793245,
# u'url': u'https://engineering.tumblr.com/',
# u'uuid': u't:CwoihvyyOxn8Mk5TUS0KDg'}
# {u'description': u'',
# u'name': u'staff',
# u'title': u'Tumblr Staff',
# u'updated': 1545058816,
# u'url': u'https://staff.tumblr.com/',
# u'uuid': u't:0aY0xL2Fi1OFJg4YxpmegQ'}
#
# JSON pretty-printed
# {
# "updated": 1539793245,
# "uuid": "t:CwoihvyyOxn8Mk5TUS0KDg",
# "title": "Tumblr Engineering",
# "url": "https://engineering.tumblr.com/",
# "name": "engineering",
# "description": "Dispatches from the intrepid tinkerers behind technology at Tumblr."
# }
# {
# "updated": 1545058816,
# "uuid": "t:0aY0xL2Fi1OFJg4YxpmegQ",
# "title": "Tumblr Staff",
# "url": "https://staff.tumblr.com/",
# "name": "staff",
# "description": ""
# }
Эти словари имеют ключ url
, поэтому вы можете распечатать их с помощью:
...
usrFollowing = client.following()
for blog in usrFollowing['blogs']:
print(blog['url'])
# outputs something like:
# https://engineering.tumblr.com/
# https://staff.tumblr.com/
values['blogs']
- это список, поэтому вам нужно перебирать его или указывать целочисленный индекс, напримерvalues['blogs'][0]['name']
. Помогло бы показать, на что вы назначаетеusrFollowing
.