# 导入随机模块,用于生成随机整数
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. 运行结果是自动下载图片