Python实现壁纸下载与轮换
作者:华丽的码农 发布时间:2022-07-01 19:19:19
标签:python,壁纸,下载,轮换
准备
下载安装Python3
官网下载即可,选择合适的版本:https://www.python.org/downloads/
安装一直下一步即可,记得勾选添加到环境变量。
安装pypiwin32
执行设置壁纸操作需要调用Windows系统的API,需要安装pypiwin32,控制台执行如下命令:
pip install pypiwin32
工作原理
两个线程,一个用来下载壁纸,一个用来轮换壁纸。每个线程内部均做定时处理,通过在配置文件中配置的等待时间来实现定时执行的功能。
壁纸下载线程
简易的爬虫工具,查询目标壁纸网站,过滤出有效连接,逐个遍历下载壁纸。
壁纸轮换线程
遍历存储壁纸的目录,随机选择一张壁纸路径,并使用pypiwin32库设置壁纸。
部分代码
线程创建与配置文件读取
def main():
# 加载现有配置文件
conf = configparser.ConfigParser()
# 读取配置文件
conf.read("conf.ini")
# 读取配置项目
search = conf.get('config', 'search')
max_page = conf.getint('config','max_page')
loop = conf.getint('config','loop')
download = conf.getint('config','download')
# 壁纸轮换线程
t1 = Thread(target=loop_wallpaper,args=(loop,))
t1.start()
# 壁纸下载线程
t2 = Thread(target=download_wallpaper,args=(max_page,search,download))
t2.start()
遍历图片随机设置壁纸
def searchImage():
# 获取壁纸路径
imagePath = os.path.abspath(os.curdir) + '\images'
if not os.path.exists(imagePath):
os.makedirs(imagePath)
# 获取路径下文件
files = os.listdir(imagePath)
# 随机生成壁纸索引
if len(files) == 0:
return
index = random.randint(0,len(files)-1)
for i in range(0,len(files)):
path = os.path.join(imagePath,files[i])
# if os.path.isfile(path):
if i == index:
if path.endswith(".jpg") or path.endswith(".bmp"):
setWallPaper(path)
else:
print("不支持该类型文件")
设置壁纸
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 crawl(page,search):
# 1\. 进入壁纸查询页面
hub_url = 'https://wallhaven.cc/search?q=' + search + '&sorting=random&page=' + str(page)
res = requests.get(hub_url)
html = res.text
# 2\. 获取链接
## 2.1 匹配 'href'
links = re.findall(r'href=[\'"]?(.*?)[\'"\s]', html)
print('find links:', len(links))
news_links = []
## 2.2 过滤需要的链接
for link in links:
if not link.startswith('https://wallhaven.cc/w/'):
continue
news_links.append(link)
print('find news links:', len(news_links))
# 3\. 遍历有效链接进入详情
for link in news_links:
html = requests.get(link).text
fing_pic_url(link, html)
print('下载成功,当前页码:'+str(page));
图片下载
def urllib_download(url):
#设置目录下载图片
robot = './images/'
file_name = url.split('/')[-1]
path = robot + file_name
if os.path.exists(path):
print('文件已经存在')
else:
url=url.replace('\\','')
print(url)
r=requests.get(url,timeout=60)
r.raise_for_status()
r.encoding=r.apparent_encoding
print('准备下载')
if not os.path.exists(robot):
os.makedirs(robot)
with open(path,'wb') as f:
f.write(r.content)
f.close()
print(path+' 文件保存成功')
import部分
import re
import time
import requests
import os
import configparser
import random
import tldextract #pip install tldextract
import win32api, win32gui, win32con
from threading import Thread
完整代码请查看GitHub:https://github.com/codernice/wallpaper
知识点
threading:多线程,这里用来创建壁纸下载和壁纸轮换两个线程。
requests:这里用get获取页面,并获取最终的壁纸链接
pypiwin32:访问windows系统API的库,这里用来设置壁纸。
configparser:配置文件操作,用来读取线程等待时间和一些下载配置。
os:文件操作,这里用来存储文件,遍历文件,获取路径等。
作者:华丽的码农
邮箱:codernice@163.com
个人博客:https://www.codernice.top
GitHub:https://github.com/codernice
来源:https://www.cnblogs.com/codernice/p/11685333.html
0
投稿
猜你喜欢
- 终于下决心把python从2.7升到了3.7。懒人安装当然使用Anaconda。安装成功,编译成功。但是用pip 安装包的时候提示:pip
- 1.游戏背景介绍(写在前面的废话): 五月初的某天,看到某网推荐了这款游戏,Pongo,看着还不错的样子
- 更改mysql密码-- 查询用户权限show grants for 'root'@'%';update my
- 一、首先进入官网https://www.python.org/1.点击Downloads 如图显示3.91 点击2.双击安装程序,进入下面的
- 1. str.format():使用“{}”占位符格式化字符串(占位符中的索引号形式和键值对形式可以混合使用)。>>> s
- 一、前言在近半年的 Python 命令行旅程中,我们依次学习了 argparse 、 docopt 、 click 和 fire 库的特点和
- scrapy爬虫框架介绍scrapy不是一个简单的函数功能库,而是一个爬虫框架爬虫框架:爬虫框架是实现爬虫功能的一个软件结构和功能组件的集合
- 前言今天就来理一理session、cookie、token这三者之间的关系!1.为什么会有它们?我们都知道 HTTP 协议是无状态的,所谓的
- numpy数组转置可以通过arr.T、arr.transpose()、arr.swapaxes()实现。数组转置 arr.T轴变换 arr.
- 目录一、Python 中的作用域规则和嵌套函数二、定义闭包函数三、何时使用闭包?四、总结一、Python 中的作用域规则和嵌套函数每当执行一
- 如下所示://动态删除select中的所有options: function delAllOptions(){&nb
- auth模块简介auth模块是对登录认证方法的一种封装,之前我们获取用户输入的用户名及密码后需要自己从user表里查询有没有用户名和密码符合
- 先看看效果图:简单的分页js代码:1、效果描述: 不用分页即可显示的jQuery插件 jQuery分页插件——jQu
- 问题描述:情况是这样的,我需要在小程序中通过image标签显示三张我的图片,毫无疑问,其重点部分肯定在image的src属性上,请看思路分析
- APScheduler简介在平常的工作中几乎有一半的功能模块都需要定时任务来推动,例如项目中有一个定时统计程序,定时爬出网站的URL程序,定
- 目录普通分页查询如何优化偏移量大采用id限定方式优化数据量大问题普通分页查询当我们在日常工作中遇到大数据查询的时候,第一反应就是使用分页查询
- 简介Pycharm安装以后必须激活后,才能正常的使用。否则就不能使用。激活PyCharm1、Activation code激活优点:Wind
- class torch.nn.Sequential(* args)一个时序容器。Modules 会以他们传入的顺序被添加到容器中。当然,也可
- 这年头,信息和获得信息的渠道越来越多。随着信息量的增大,先有了分类,又有了导航,再有了搜索,后面的发展还不得而知。在此只是根据平日的所看所想
- 本文实例讲述了python计算时间差的方法。分享给大家供大家参考。具体分析如下:1、问题:给定你两个日期,如何计算这两个日期之间间隔几天,几