圆月山庄资源网 Design By www.vgjia.com
Python下载中央气象台卫星云图后保存为gif并播放,大致步骤:
- 获取URL
- 下载图片
- 合成GIF
- 播放GIF
1.获取URL
1.1 先下载一份网页源码看看网页结构
保存为:response.txt
#http库 import requests #准备http请求头 headers = {"user-agent": "firefox"} #中央气象台卫星云图网页 url = 'http://www.nmc.cn/publish/satellite/fy2.htm' #获取网页 r = requests.get(url, headers=headers) #改编码方式支持中文 r.encoding='utf-8' #保存为文本 with open('response.txt','w', encoding='utf-8') as f: f.write(r.text)
1.2 到网页查看图片链接
右键图片---查看元素
图片链接如下:可以看到图片链接的域名和网页域名不同。
src=http://image.nmc.cn/product/2020/02/16/WXCL/medium/SEVP_NSMC_WXCL_ASC_E99_ACHN_LNO_PY_20200216091500000.JPG"text-align: center">1.4 过滤出script,找到所有url
使用html解析库解析出script,script的开头type="text/javascript"作为过滤条件,结果打印看看:
#html/xml解析库 from lxml import etree #解析response html = etree.HTML(r.text) result = html.xpath('//script[@type="text/javascript"]/text()')[2] print(result)打印结果如下,可以看到是多行字符串。
根据图片的链接规律,可以用正则匹配出来:
#正则库 import re urls = re.findall('/product.*.JPG', result) print(urls)成功匹配出图片url。注意这里的url只有后半部分,根据之前的图片链接可知,实际图片url还需加上:http://image.mnc.cn。
1.5 因此写获取图片URL函数
def getpage(page): try: r = requests.get(page, headers=headers) html = etree.HTML(r.text) result = html.xpath('//script[@type="text/javascript"]/text()')[2] urls = re.findall('/product.*.JPG', result) return urls except Exception as e: print(e)2.下载图片
拿到图片url的列表后,就是下载图片:
#url前缀 base_url = 'http://image.nmc.cn' def dlpic(urls): # 定义一个文件名称收集列表 filenames = [] for item in urls: r = requests.get(base_url + item, headers) #文件名就是用斜杠把字符串分隔,取走后后一个字符串 filename = item.split('/')[-1] filenames.append(filename) #保存图片 with open('wxyt_pic\\' + filename, 'wb') as f: f.write(r.content) print('已下载:'+item) #返回文件名称列表,用于合成gif return filenames3.合成图片
# 图片操作库 import imageio def makegif(images): # 创建空列表,把图片明反序 frames = [] images.reverse() # 加载12张图片 for item in images: frames.append(imageio.imread('wxyt_pic\\'+item)) # 合成1张gif imageio.mimsave('hecheng.gif', frames, 'GIF', duration=1)4.播放图片
def playgif(seq=0): if set == 0: #播放12张合成好的gif animation = pyglet.resource.animation('hecheng.gif') else: pyglet.resource.path = ['wxyt_pic'] la = os.listdir('wxyt_pic') images = [] for n in la: images.append(pyglet.resource.image(n)) #播放库存中的所有照片 animation = pyglet.image.Animation.from_image_sequence(images, period=0.5, loop=True) #显示动画 sprite = pyglet.sprite.Sprite(animation) windows = pyglet.window.Window(width=sprite.width, height=sprite.height) @windows.event def on_draw(): windows.clear() sprite.draw() pyglet.app.run()5.整体代码
import requests from lxml import etree import imageio import re import pyglet import os # 在脚本同目录下,新建一个文件夹,存储当天12张图 def ckdir(): if os.path.exists('wxyt_pic') == False: os.mkdir('wxyt_pic') # 获取图片url列表 def getpage(page): try: r = requests.get(page, headers=headers) html = etree.HTML(r.text) result = html.xpath('//script[@type="text/javascript"]/text()')[2] urls = re.findall('/product.*.JPG', result) return urls except Exception as e: print(e) # 下载图片 def dlpic(urls): filenames = [] for item in urls: r = requests.get(base_url + item, headers) filename = item.split('/')[-1] filenames.append(filename) with open('wxyt_pic\\' + filename, 'wb') as f: f.write(r.content) print('已下载:'+item) return filenames # 制作gif def makegif(images): frames = [] images.reverse() for item in images: frames.append(imageio.imread('wxyt_pic\\'+item)) imageio.mimsave('hecheng.gif', frames, 'GIF', duration=1) # 播放gif def playgif(seq=0): if set == 0: #播放12张合成好的gif animation = pyglet.resource.animation('hecheng.gif') else: pyglet.resource.path = ['wxyt_pic'] la = os.listdir('wxyt_pic') images = [] for n in la: images.append(pyglet.resource.image(n)) #播放库存中的所有照片 animation = pyglet.image.Animation.from_image_sequence(images, period=0.5, loop=True) #显示动画 sprite = pyglet.sprite.Sprite(animation) windows = pyglet.window.Window(width=sprite.width, height=sprite.height) @windows.event def on_draw(): windows.clear() sprite.draw() pyglet.app.run() # init if __name__ == '__main__': base_url = 'http://image.nmc.cn' page = 'http://www.nmc.cn/publish/satellite/fy2.htm' headers = {"user-agent": "firefox"} ckdir() urls = getpage(page) images = dlpic(urls) makegif(images) # 0只播放今天12张,1播放库存里所有照片 playgif(1)6.最终效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月02日
2024年11月02日
- 张韶涵2024 《不负韶华》开盘母带[低速原抓WAV+CUE][1.1G]
- lol全球总决赛lcs三号种子是谁 S14全球总决赛lcs三号种子队伍介绍
- lol全球总决赛lck三号种子是谁 S14全球总决赛lck三号种子队伍
- 群星.2005-三里屯音乐之男孩女孩的情人节【太合麦田】【WAV+CUE】
- 崔健.2005-给你一点颜色【东西音乐】【WAV+CUE】
- 南台湾小姑娘.1998-心爱,等一下【大旗】【WAV+CUE】
- 【新世纪】群星-美丽人生(CestLaVie)(6CD)[WAV+CUE]
- ProteanQuartet-Tempusomniavincit(2024)[24-WAV]
- SirEdwardElgarconductsElgar[FLAC+CUE]
- 田震《20世纪中华歌坛名人百集珍藏版》[WAV+CUE][1G]
- BEYOND《大地》24K金蝶限量编号[低速原抓WAV+CUE][986M]
- 陈奕迅《准备中 SACD》[日本限量版] [WAV+CUE][1.2G]
- TWINS.2004-SUCHABETTERDAY精美礼盒特别版2CD【英皇娱乐】【WAV+CUE】
- 音乐磁场.1991-1998-音乐磁场系列22CD【瑞星】【WAV+CUE】
- 韦绮姗.1993-LOVE.ME.ONCE.AGAIN【永高创意】【WAV+CUE】