# coding: utf-8
import requests
from operator import itemgetter
# --------------------------------执行API调用并存储响应------------------------------------------------------------------
url = 'https://hacker-news.firebaseio.com/v0/topstories.json'
r = requests.get(url)
print("Status code:", r.status_code)
# -------------------------------处理有关每篇文章的信息---------------------------------------------------------------
submission_ids = r.json()
submission_dicts = []
# ----------------------------对于每篇文章都执行一个API调用-----------------------------------------------------
for submission_id in submission_ids[:30]:
url = ('https://hacker-news.firebaseio.com/v0/item/' + str(submission_id) + '.json')
submission_r = requests.get(url)
print("Status Code:", r.status_code, end=',')
response_dict = submission_r.json()
submission_dict = {'title': response_dict['title'],
'link': 'http://news.ycombinator.com/item?id=' + str(submission_id),
'comments': response_dict.get('descendants', 0)}
submission_dicts.append(submission_dict)
# ---------------------------------------------------------------------------------------------------------------
submission_dicts_new = sorted(submission_dicts, key=itemgetter('comments'), reverse=True)
for submission in submission_dicts_new:
print("\nTitle:", submission['title'])
API项目——Hacker News网站上的热门文章
最新推荐文章于 2023-05-03 16:24:18 发布