Python自动化脚本指南(pythonui自动化脚本)
off999 2025-05-08 04:43 36 浏览 0 评论
以下是一个实用的 Python 自动化脚本指南,包含常见场景示例和分步说明:
一、环境准备
- 安装 Python (推荐 3.6+ 版本)
- 安装常用库:
bash
pip install requests beautifulsoup4 openpyxl python-docx schedule pyautogui
二、常见自动化场景示例
1. 文件管理自动化
python
import os
import shutil
from pathlib import Path
# 自动整理下载文件夹
DOWNLOADS = Path.home() / "Downloads"
# 按扩展名创建目录
CATEGORIES = {
"Images": [".jpg", ".png", ".gif"],
"Documents": [".pdf", ".docx", ".txt"],
"Archives": [".zip", ".rar"]
}
for file in DOWNLOADS.iterdir():
if file.is_file():
for category, exts in CATEGORIES.items():
if file.suffix.lower() in exts:
dest = DOWNLOADS / category
dest.mkdir(exist_ok=True)
shutil.move(str(file), str(dest))
break
2. 网页数据抓取
python
import requests
from bs4 import BeautifulSoup
def get_weather(city="beijing"):
url = f"https://www.tianqi.com/{city}/"
response = requests.get(url)
soup = BeautifulSoup(response.text, 'html.parser')
weather_info = {
"city": soup.find('dd', class_='name').h2.text,
"temp": soup.find('p', class_='now').b.text,
"status": soup.find('span', class_='text').text
}
return weather_info
print(get_weather("shanghai"))
3. Excel 报表自动化
python
from openpyxl import Workbook
from datetime import datetime
def create_report(data):
wb = Workbook()
ws = wb.active
ws.title = "销售报告"
# 添加标题行
headers = ["日期", "产品", "销售额"]
ws.append(headers)
# 填充数据
for row in data:
ws.append(row)
# 自动调整列宽
for col in ws.columns:
max_length = 0
for cell in col:
try:
if len(str(cell.value)) > max_length:
max_length = len(cell.value)
except:
pass
adjusted_width = (max_length + 2) * 1.2
ws.column_dimensions[col[0].column_letter].width = adjusted_width
filename = f"report_{datetime.now().strftime('%Y%m%d')}.xlsx"
wb.save(filename)
# 示例数据
sales_data = [
["2023-08-01", "产品A", 15000],
["2023-08-01", "产品B", 23000],
["2023-08-02", "产品A", 18000]
]
create_report(sales_data)
4. 邮件自动化
python
import smtplib
from email.mime.text import MIMEText
from email.mime.multipart import MIMEMultipart
import getpass
def send_email(subject, body, to_email):
# 配置信息
email = "your_email@example.com"
password = getpass.getpass("输入邮箱密码:")
# 创建邮件
msg = MIMEMultipart()
msg['From'] = email
msg['To'] = to_email
msg['Subject'] = subject
# 添加正文
msg.attach(MIMEText(body, 'plain'))
# 发送邮件
try:
server = smtplib.SMTP('smtp.example.com', 587)
server.starttls()
server.login(email, password)
server.sendmail(email, to_email, msg.as_string())
print("邮件发送成功!")
except Exception as e:
print(f"发送失败:{str(e)}")
finally:
server.quit()
# 使用示例
send_email("每日报告", "这是自动发送的日报内容...", "recipient@example.com")
5. 桌面自动化 (GUI 操作)
python
import pyautogui
import time
def auto_screenshot(interval=5, duration=60):
"""定时截屏"""
end_time = time.time() + duration
while time.time() < end_time:
screenshot = pyautogui.screenshot()
timestamp = time.strftime("%Y%m%d_%H%M%S")
screenshot.save(f"screenshot_{timestamp}.png")
time.sleep(interval)
auto_screenshot(duration=30) # 运行30秒,每5秒截屏一次
三、高级技巧
- 定时任务设置
python
import schedule
import time
def job():
print("定时任务执行中...")
# 每天10:30执行
schedule.every().day.at("10:30").do(job)
while True:
schedule.run_pending()
time.sleep(60) # 每分钟检查一次
- 异常处理模板
python
def safe_automation():
try:
# 你的自动化代码
except FileNotFoundError as e:
print(f"文件未找到: {str(e)}")
except KeyboardInterrupt:
print("用户中断操作")
except Exception as e:
print(f"未知错误: {str(e)}")
finally:
# 清理资源
print("任务执行完毕")
四、最佳实践建议
- 使用配置文件存储敏感信息(API密钥、密码等)
- 添加详细的日志记录
- 编写可配置的参数(通过命令行参数或配置文件)
- 使用版本控制(Git)管理脚本
- 添加必要的异常处理
- 在虚拟环境中运行(使用 venv 或 conda)
五、调试技巧
- 使用 print() 进行简单调试
- 使用 logging 模块记录运行日志
- 使用 IDE 的调试功能(如 VSCode、PyCharm)
- 处理路径时使用 pathlib 代替字符串拼接
- 使用 type() 和 dir() 检查对象类型和属性
这些示例覆盖了常见的自动化场景,可以根据具体需求进行组合和扩展。建议从简单任务开始,逐步增加复杂度,同时注意做好错误处理和日志记录。
相关推荐
- 安全教育登录入口平台(安全教育登录入口平台官网)
-
122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...
- 大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)
-
大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...
-
- 哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
-
要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...
-
2026-02-04 09:03 off999
- 电信宽带测速官网入口(电信宽带测速官网入口app)
-
这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...
- 植物大战僵尸95版手机下载(植物大战僵尸95 版下载)
-
1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...
- 免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)
-
1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...
- 2025世界杯赛程表(2025世界杯在哪个国家)
-
2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...
- 下载搜狐视频电视剧(搜狐电视剧下载安装)
-
搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...
- 永久免费听歌网站(丫丫音乐网)
-
可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...
- 音乐格式转换mp3软件(音乐格式转换器免费版)
-
有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...
- 电子书txt下载(免费的最全的小说阅读器)
-
1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...
- 最好免费观看高清电影(播放免费的最好看的电影)
-
在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...
- 孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)
-
要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
