【Python学习】Python通过API获取网络数据


# 导入随机模块,用于生成随机整数
from random import randint
# 导入请求模块,用于向指定的url发送请求
import requests
# 导入时间模块,用于获取当前时间
from time import time
# 导入线程模块,用于创建新的线程
from threading import Thread

# 定义一个下载处理器类,继承Thread类
class DownloadHanlder(Thread):
    # 定义类的初始化函数
    def __init__(self, url):
        # 调用父类的初始化函数
        super().__init__()
        # 将传入的url保存到类的实例中
        self._url = url

    # 定义类的运行函数,在线程中执行
    def run(self):
        # 生成一个随机文件名
        filename = str(randint(0, 100000)) + ".jpg"
        # 向self._url发送get请求,返回响应结果resp
        resp = requests.get(self._url)
        # 以写入二进制模式打开文件"Data/News/" + filename,将响应内容写入文件
        with open("Data/News/" + filename, "wb") as f:
            f.write(resp.content)

# 定义主函数
def main():
    # 定义apiKey变量,值为"8a188324d3341591bea014aed31b0fa2"
    apiKey = "8a188324d3341591bea014aed31b0fa2"
    # 向指定的url发送get请求,返回响应结果resp,该url包含apiKey参数和一个需要获取数据的数字参数num=10
    resp = requests.get("https://apis.tianapi.com/ai/index?key=%s&num=10" % apiKey)
    # 将响应结果转化为json格式数据并保存到data_model变量中
    data_model = resp.json()
    # 遍历data_model["result"]["newslist"]列表中的每个字典元素mm_dict,获取其中的"picUrl"值并保存到url变量中
    for mm_dict in data_model["result"]["newslist"]:
        url = mm_dict["picUrl"]
        # 创建DownloadHanlder类的实例,传入url作为参数,并调用start方法启动线程执行下载操作
        DownloadHanlder(url).start()

# 如果当前运行的脚本是主程序,执行main函数,否则忽略执行。此方法与条件判断语句if __name__ == "__main__":一起使用,保证脚本的可重用性。
if __name__ == "__main__":
    main()```

注意:

1. 代码中使用了HTTP请求GET/POST接口测试工具 - 天行数据TianAPI 提供的免费测试API,其他免费的API网站也可以,并非广告

2. API key在网站中获取

3. 运行结果是自动下载图片

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值