百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python自动化脚本指南(pythonui自动化脚本)

off999 2025-05-08 04:43 4 浏览 0 评论

以下是一个实用的 Python 自动化脚本指南,包含常见场景示例和分步说明:

一、环境准备

  1. 安装 Python (推荐 3.6+ 版本)
  2. 安装常用库:

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秒截屏一次

三、高级技巧

  1. 定时任务设置

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) # 每分钟检查一次

  1. 异常处理模板

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("任务执行完毕")

四、最佳实践建议

  1. 使用配置文件存储敏感信息(API密钥、密码等)
  2. 添加详细的日志记录
  3. 编写可配置的参数(通过命令行参数或配置文件)
  4. 使用版本控制(Git)管理脚本
  5. 添加必要的异常处理
  6. 在虚拟环境中运行(使用 venv 或 conda)

五、调试技巧

  1. 使用 print() 进行简单调试
  2. 使用 logging 模块记录运行日志
  3. 使用 IDE 的调试功能(如 VSCode、PyCharm)
  4. 处理路径时使用 pathlib 代替字符串拼接
  5. 使用 type()dir() 检查对象类型和属性

这些示例覆盖了常见的自动化场景,可以根据具体需求进行组合和扩展。建议从简单任务开始,逐步增加复杂度,同时注意做好错误处理和日志记录。

相关推荐

Python写每天进步1%的力量(python计算每天进步一点点)

离别了学生时代,步入了职场,你还记得你离上一次打开书本是在什么时候吗?认真上课,看学习视频,静下心来,虽唾手可得,却似乎离我们越来越远。每天忙着忙着,不知道自己忙什么,只是连坐下来停下思考5分钟的时间...

Python高级特性揭秘:14个鲜为人知的编程秘籍

引言:Python的隐藏宝藏Python作为全球最受欢迎的编程语言之一,以其简洁和易用性著称。然而,许多开发者在日常工作中只触及了Python的表面,错过了许多强大而高效的高级特性。这些特性不仅能让代...

Python自动化脚本指南(pythonui自动化脚本)

以下是一个实用的Python自动化脚本指南,包含常见场景示例和分步说明:一、环境准备安装Python(推荐3.6+版本)安装常用库:bashpipinstallrequestsbea...

python面向对象四大支柱——多态(python面向对象总结)

Python面向对象多态(Polymorphism)详解多态是面向对象编程的四大支柱之一,它允许不同类的对象对同一消息(方法调用)做出不同的响应。下面我将全面详细地讲解Python中的多态概念及其实现...

主编推荐 | Gurobi 并行计算的设置和操作(附代码)

『运筹OR帷幄』原创作者:运筹OR帷幄编者按实际应用问题往往具有较高的计算复杂度,而优化算法难以在实际中落地的主要瓶颈就在于无法满足实际问题对计算时间的苛刻要求。然而近年来随着计算力的蓬勃发展,并行计...

Python 空值(None)详解(python 给空值赋值)

在Python中,空值是一个非常重要的概念,表示"没有值"或"空"的状态。让我们来详细了解一下。什么是空值?在Python中,空值用None表示。它是一个特殊的数据类型...

python学习——032关于函数接收的参数和返回值

在Python里,函数的参数和返回值都能是字符(字符串)、列表、字典等多种类型的数据,这大大提升了函数的灵活性和复用性。下面为举例说明:1.参数和返回值为字符串defgreet(name):...

一文理解 Python 中的类型提示(python 类的作用)

Python的流行源于其简洁性和可读性。然而,作为一种动态类型语言,其灵活性有时会导致运行时错误和由于数据类型不正确而出现意外行为。这是类型提示和静态类型检查发挥作用的地方,为Python代码...

新手学Python避坑,学习效率狂飙! 二十三、Python 闭包问题

感谢大家对《新手学Python避坑,学习效率狂飙!》系列的点赞、关注和收藏,今天这编是这个系列的第二十三个分享,前面还有二十二个,大家可以关注下之前发布的文章。下面是我们今天的分享:闭包的定义与原理在...

一个用 Rust 开发的极快、易用的 Python 包和项目管理利器

uv是一个全新的、由Astral团队(就是那个开发了Ruff的团队)采用Rust开发的高性能的Python包和项目管理工具。它的目标是取代传统的pip和pip-tools,提供...

脱颖而出的Python xlwings模块,一个更强大的操作Excel的模块

如下,在Python中存在很多支持Excel操作的第三方库,那么本文介绍的xlwings模块有其它模块有何区别呢?xrldxlwtopenpyxlxlswriterpandaswin32comxl...

一小时学会用Python开发微信AI机器人:从零到企业级应用实战

一、企业微信API接入流程:打造合法合规的机器人通道1.1企业微信与个人微信的区别企业微信三大优势:1.官方API支持(合规性保障)2.支持多终端消息同步3.可扩展企业级功能(审批/打卡...

Python 进阶-day24: API 开发(python的api)

学习目标理解RESTfulAPI的核心概念和设计原则。使用Flask创建模块化的RESTfulAPI,包含优雅的数据库访问代码。为博客应用实现API接口,支持CRUD操作(创建、...

PyQt5 库:强大的 Python GUI 开发利器

一、引言在Python的众多应用领域中,图形用户界面(GUI)开发是一个重要的方面。PyQt5库作为一个功能强大且广泛应用的GUI框架,为开发者提供了丰富的工具和组件,使得创建交互式、美观的...

探秘:Python 类为何继承 object(python中的类都继承于object)

在Python的编程世界里,我们常常会看到这样的代码:classMyClass(object):,这里的类继承了object。那么,Python类为什么要继承object呢?今天咱们...

取消回复欢迎 发表评论: