Bing(必应)每日一图下载

16次阅读
没有评论

Bing(必应)每日一图下载

灵感 & 说明 :
得益于一个偶然的浏览,发现有博主利用 php实现对必应每日一图的解析和获取,
于是利用python对其进行复现(虽然有可直接用的接口,而毕竟是别人的!😥),并添加一定的功能!

21/06/04 :初代版本 ,提供图片下载并可自定义设为壁纸.
21/07/06 : 期间太忙,后续使用中发现代码过于臃肿,控制窗口显示非必要信息过多,精简并添加对图片信息和链接文件的储存!

python源码(可自行增删功能,变量名过于随意海涵。。。)
有兴趣查看php版源码的:点击跳转

[Python] 纯文本查看 复制代码

# [url=home.php?mod=space&uid=267492]@file[/url] : bing_lym.py
# [url=home.php?mod=space&uid=238618]@Time[/url] : 2021/6/4 8:53
import re
import os
import win32api
import win32con
import win32gui
import requests
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.108 Safari/537.36'
}
''

def downloads_img(time_info, img_d_url, img_text):
path = os.getcwd() + f'/{time_info}.jpg'
with open(path, 'wb') as f:
f.write(requests.get(img_d_url, headers=headers).content)
path_ = os.getcwd() + f'/{time_info}.txt'
with open(path_, 'w', encoding='utf-8') as f_:
f_.write(img_text + '\n' + img_d_url)
print("*-> 文件链接", img_d_url)
print(f"*-> 文件 {time_info}.jpg --> 下载成功!")

def get_res_html():
aspx_url = 'http://cn.bing.com/HPImageArchive.aspx?idx=0&n=1'
img_html = requests.get(url=aspx_url, headers=headers).text
# print(img_html)
date_info = re.findall('<fullstartdate>(.*?)</fullstartdate>', img_html)[0]
img_info = re.findall('<url>(.*?)</url>', img_html)[0]
# 07_06 加入关于图片说明
img_text = re.findall('<copyright>(.*?)</copyright>', img_html)[0]
print(' date_info -> %s\n img_info -> %s\n img_text -> %s' % (date_info, img_info, img_text))
return date_info, img_info, img_text

def setWallPaper(pic):
# open register
regKey = win32api.RegOpenKeyEx(win32con.HKEY_CURRENT_USER, "Control Panel\\Desktop", 0, win32con.KEY_SET_VALUE)
win32api.RegSetValueEx(regKey, "WallpaperStyle", 0, win32con.REG_SZ, "2")
win32api.RegSetValueEx(regKey, "TileWallpaper", 0, win32con.REG_SZ, "0")
# refresh screen
win32gui.SystemParametersInfo(win32con.SPI_SETDESKWALLPAPER, pic, win32con.SPIF_SENDWININICHANGE)

def img_main():
bing_url = 'https://cn.bing.com'
date_info, img_info, img_text = get_res_html()
# 下载函数
downloads_img(time_info=date_info, img_d_url=bing_url + img_info, img_text=img_text)
# 绝对路径储存
path = os.getcwd() + f'/{date_info}.jpg'
# print(type(path), path)
pd = input('> 更换壁纸? y/n :')
if pd == "y":
setWallPaper(pic=path)
else:
pass

if __name__ == '__main__':
img_main()

程序图片:

成品可执行文件:https://jingmo.lanzoui.com/IDA7Ur2z33a

正文完
 0
116博客
版权声明:本篇文章由 116博客 于2024-11-30发表,共计2149字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
评论(没有评论)
验证码