当前位置:
首页 > temp > python入门教程 >
-
用Python将女朋友的照片做成壁纸软件,实现桌面壁纸自动更换!
算了,还是回到正题吧,再说我要挨打了~
今天咱们来交流一下程序员是怎么哄女朋友的,话不多说直接开始!
准备工作
1、环境
首先我们准备好环境和编辑器,我使用的是:
- Python 3.8 解释器
- Pycharm 编辑器
2、使用的模块
import re # 正则表达式模块 import requests # 数据请求模块 import os # 文件操作模块 import ctypes # 时间模块
request是第三方模块,需要手动安装一下,win + R
输入cmd
输入安装命令pip install requests
其它的都是自带的,不用安装,直接调用。
3、如何配置pycharm里面的python解释器?
- 选择file(文件) >>> setting(设置) >>> Project(项目) >>> python interpreter(python解释器)
- 点击齿轮, 选择add
- 添加python安装路径
4、pycharm如何安装插件?
- 选择file(文件) >>> setting(设置) >>> Plugins(插件)
- 点击 Marketplace 输入想要安装的插件名字 比如:翻译插件 输入 translation / 汉化插件 输入 Chinese
- 选择相应的插件点击 install(安装) 即可
- 安装成功之后 是会弹出 重启pycharm的选项 点击确定, 重启即可生效
代码实战
为了单身的小伙伴,于是我将案例分为两个部分。
- 获取壁纸
- 设置自动更换
当然,不单身的话直接看第二部分,哈哈~
1、获取壁纸
首先来实现单张壁纸获取
这里分为四个步骤来获取壁纸,后面的网址我都屏蔽一下,防止检测。
- 发送请求, 对于 http://www.***.com/desk/31131.htm 发送请求
- 获取数据, 获取网页源代码 <服务器返回响应数据>
- 解析数据, 提取我们想要的数据内容 壁纸链接以及名字
- 保存数据, 把壁纸文件保存到本地文件
发送请求
for page in range(3, 21): print(f'正在采集第{page}页的数据内容') # 请求链接 link = f'http://www.****.com/index_{page}.htm' # 发送请求 html_data = requests.get(link).text # 提取ID img_id_list = re.findall('<a href="/desk/(\d+)\.htm" title=', html_data) # for循环遍历 for img_id in img_id_list: # 请求链接 url = f'http://www.***.com/desk/{img_id}.htm' # 发送请求 response = requests.get(url)
获取数据
response.text 获取响应文本数据
response.encoding = response.apparent_encoding 自动识别码
解析数据
# 获得到数据, 返回出现乱码了 response.encoding = 'gbk' # 链接地址 以及 标题 img, title = re.findall('<img src="(.*?)" alt="(.*?)"', response.text)[0] print(img, title)
保存数据
# 发送请求, 获取数据 # 完整源码+视频讲解+表白墙代码 # 都放在这个抠裙了:815624229 img_content = requests.get(img).content with open('img\\' + title + '.jpg', mode='wb') as f: f.write(img_content)
多页多个数据采集
这里只讲一下大概思路,我有专门录制视频来讲解,可以在文末获取。
一个链接, 对应一个数据,获取多个链接, 获取多个数据。
http://www.***.com/desk/31095.htm http://www.***.com/desk/31131.htm http://www.***.com/desk/31090.htm http://www.***.com/desk/31092.htm 第二页: http://www.***.com/index_2.htm 第三页: http://www.***.com/index_3.htm 第四页: http://www.***.com/index_4.htm
自动更换壁纸程序
import os import ctypes import cv2 def Change(): # 壁纸文件夹路径 wallpaper_dir = r"D:\壁纸\output" # 获取壁纸文件夹中的文件列表 wallpapers = os.listdir(wallpaper_dir) # 随机选择一张壁纸 # wallpaper_filename = random.choice(wallpapers) for wallpaper in wallpapers: # 拼接壁纸文件的完整路径 wallpaper_path = os.path.join(wallpaper_dir, wallpaper) # 设置壁纸 ctypes.windll.user32.SystemParametersInfoW(20, 0, wallpaper_path, 3) def convert_mp4_to_jpgs(path): video_capture = cv2.VideoCapture(path) still_reading, image = video_capture.read() frame_count = 5 # 保存的起始帧的编号005 while still_reading: cv2.imwrite(f"output/frame_{frame_count:03d}.jpg", image) # read next image still_reading, image = video_capture.read() frame_count += 5 # 保存帧依次增加5,005>>010>>015....... Change()
出处:https://www.cnblogs.com/hahaa/p/17421564.html
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数