python 10个自动化脚本

目录

🌟 引言

📚 理论基础

🛠️ 使用场景与代码示例

场景一:批量重命名文件

场景二:自动下载网页内容

场景三:数据清洗

场景四:定时执行任务

场景五:自动化邮件发送

场景六:自动化测试

场景七:数据库操作

场景八:日志分析

场景九:文件压缩

场景十:自动化文档生成

🎉 结语



🌟 引言

在程序员的世界里,自动化是提升效率的金钥匙。Python,以其易读性和强大的库支持,成为了实现自动化任务的首选语言。本文精选了10个实用的Python自动化脚本,涵盖文件处理、网络请求、数据分析等多个领域,旨在帮你节省时间,减少重复劳动,提升工作效能。

📚 理论基础

Python的自动化脚本主要依赖于标准库和第三方库,如os、requests、pandas等。通过这些库,我们可以轻松实现文件操作、数据抓取、数据分析等功能。

🛠️ 使用场景与代码示例

场景一:批量重命名文件

在处理大量媒体文件时,统一命名规则非常必要。

代码示例
import os
def batch_rename(directory, prefix):i = 1for filename in os.listdir(directory):ext = os.path.splitext(filename)[1]new_name = f"{prefix}_{i}{ext}"os.rename(os.path.join(directory, filename), os.path.join(directory, new_name))i += 1
batch_rename('/path/to/directory', 'file')

场景二:自动下载网页内容

对于研究者或数据分析师来说,自动抓取网络数据至关重要。​​​​​​​

代码示例
import requests
def download_webpage(url, output_file):response = requests.get(url)with open(output_file, 'w') as file:file.write(response.text)
download_webpage('http://example.com', 'webpage.html')

场景三:数据清洗

数据预处理是数据分析的重要环节。​​​​​​​

代码示例
import pandas as pd
def clean_data(file_path):df = pd.read_csv(file_path)df.dropna(inplace=True)df.to_csv(file_path, index=False)
clean_data('data.csv')

场景四:定时执行任务

确保任务在特定时间点执行,比如发送日报。

代码示例
import schedule
import time
def job():print("Task executed")
schedule.every().day.at("10:30").do(job)
while True:schedule.run_pending()time.sleep(1)

场景五:自动化邮件发送

自动发送报告,无需手动操作。​​​​​​​

代码示例
import smtplib
from email.mime.text import MIMEText
def send_email(subject, message, to_email):msg = MIMEText(message)msg['Subject'] = subjectmsg['From'] = 'you@example.com'msg['To'] = to_emails = smtplib.SMTP('localhost')s.sendmail('you@example.com', [to_email], msg.as_string())s.quit()
send_email('Daily Report', 'Here is your daily report.', 'recipient@example.com')

场景六:自动化测试

确保代码质量,每次修改后都能自动测试。​​​​​​​

代码示例
import unittest
class TestMyFunction(unittest.TestCase):def test_add(self):self.assertEqual(add(1, 2), 3)
if __name__ == '__main__':unittest.main()

场景七:数据库操作

自动化数据备份和恢复。​​​​​​​

代码示例
import sqlite3
def backup_database(db_path, backup_path):conn = sqlite3.connect(db_path)backup_conn = sqlite3.connect(backup_path)conn.backup(backup_conn)backup_conn.close()conn.close()
backup_database('database.db', 'backup.db')

场景八:日志分析

从日志文件中提取关键信息。​​​​​​​

代码示例
import re
def analyze_logs(log_file):pattern = r'\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}'with open(log_file, 'r') as file:for line in file:match = re.search(pattern, line)if match:print(match.group())
analyze_logs('access.log')

场景九:文件压缩

批量压缩文件,便于存储和传输。​​​​​​​

代码示例
import zipfile
def compress_files(file_paths, zip_file):with zipfile.ZipFile(zip_file, 'w') as myzip:for file_path in file_paths:myzip.write(file_path)
compress_files(['file1.txt', 'file2.txt'], 'archive.zip')

场景十:自动化文档生成

根据数据自动生成报告。​​​​​​​

代码示例
from docx import Document
def generate_report(data, report_file):doc = Document()doc.add_heading('Report', 0)doc.add_paragraph(str(data))doc.save(report_file)
generate_report('Sample data', 'report.docx')

🎉 结语

通过以上10个Python自动化脚本的实例,你可以看到Python在自动化领域的强大功能。无论是日常办公还是专业开发,Python都能帮助你节省时间和精力,让工作更加高效和愉快。希望你能将这些脚本融入自己的工作流程中,享受自动化带来的便利!

如果你对某个脚本特别感兴趣,或者有更多自动化需求,欢迎留言交流。让我们一起探索Python自动化世界的无限可能!🚀

请确保在运行上述代码前,已安装所有必需的Python库,如requests, pandas, schedule, unittest, sqlite3, re, zipfile, 和 docx。如果在实际应用中遇到困难,不要犹豫,随时提问,让我们一起成长!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/42976.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

极品AI大模型,抓紧收藏!整合包!

近期,科技巨头谷歌终于发布了1个月前在I/O开发者大会上预告过的Gemma 2大模型。据谷歌介绍,与第1代Gemma模型相比,新模型拥有更优的性能,推理效率也更高。我当然是,“无所谓,我会出手.jpg”,给大…

Linux 常见命令使用(超详细版)

文章目录 基本echo关机、重启命令上传下载工具rz/sz<、>、>>ls管道clearcdpwd 文件处理类命令mkdirrmdirtouchcpmv 文件查看类命令catmorelessheadtail 用户管理命令useraddpasswdusermoduserdelgroupaddgroupdel 文件属性类命令chmodchownchgrpln 文件压缩类命令t…

【多模态】40、ConvLLaVA | 使用 ConvNeXt 为 LLaVA 实现更高分辨率的输入

论文&#xff1a;ConvLLaVA: Hierarchical Backbones as Visual Encoder for Large Multimodal Models 代码&#xff1a;https://github.com/alibaba/conv-llava 出处&#xff1a;阿里 | 清华 时间&#xff1a;2024.05 一、背景 LMM 在很多任务上都表现出来很好的效果&…

ROS编译错误: fatal error: test_pkg/test_pkg.h: 没有那个文件

在ROS安装完毕后编译ros工作空间&#xff0c;出现了以下错误: 解决方法: 删除工作空间&#xff0c;重建再重新编译

vue3+ el-tree 展开和折叠,默认展开第一项

默认第一项展开: 展开所有项&#xff1a; 折叠所有项&#xff1a; <template><el-treestyle"max-width: 600px":data"treeData"node-key"id":default-expanded-keys"defaultExpandedKey":props"defaultProps"…

超好用的傲软录屏下载和解锁版安装教程 (专业好用的桌面录屏软件)

录屏系列软件安装目录 一、ZD屏幕录像机解锁版下载及安装教程 (一款小巧的轻量级屏幕录像工具) 二、班迪录屏Bandicam v7解锁版安装教程&#xff08;高清录屏软件&#xff09; 三、Mirillis Action v4 解锁版安装教程(专业高清屏幕录像软件) 四、Aiseesoft Screen Recorder…

支持图片识别语音输入的LobeChat保姆级本地部署流程

文章目录 前言1. LobeChat对我们有哪些帮助?2. 本地安装LobeChat3. 如何使用LobeChat工具4. 安装Cpolar内网穿透5. 实现公网访问LobeChat6. 固定LobeChat公网地址 前言 本文主要介绍如何在Windows系统电脑本地部署LobeChat&#xff0c;一款高颜值的开源AI大模型智能应用&…

Java学习十四—Java8特性之Lambda表达式

一、简介 Java 8 引入了 Lambda 表达式&#xff0c;它是一种更简洁、更便于使用的函数式编程特性。Lambda 表达式允许将函数作为方法的参数&#xff08;函数式接口的实例&#xff09;传递给某个方法&#xff0c;或者将代码像数据一样进行传递。 ‍ lambda是一个匿名函数&#…

LLM之RAG实战(四十一)| 使用LLamaIndex和Gemini构建高级搜索引擎

Retriever 是 RAG&#xff08;Retrieval Augmented Generation&#xff09;管道中最重要的部分。在本文中&#xff0c;我们将使用 LlamaIndex 实现一个结合关键字和向量搜索检索器的自定义检索器&#xff0c;并且使用 Gemini大模型来进行多个文档聊天。 通过本文&#xff0c;我…

明确产业定位,用科学规划铸就高品质文化产业园

科学规划是构建高品质文化产业园区的重要保障。通过明确产业定位与发展目标、科学规划空间布局、完善基础设施与配套设施、注重生态环境保护、加强人才引进与培养以及推动产业协同发展等措施的实施&#xff0c;可以推动文化产业园区向高品质、高效益、可持续的方向发展。 一、明…

【TB作品】51单片机 Proteus仿真 超声波读取+LCD1602显示仿真12MHZ

实验报告&#xff1a;51单片机 Proteus仿真 超声波读取LCD1602显示仿真 一、实验背景 本实验旨在使用51单片机&#xff08;AT89C51&#xff09;结合超声波传感器HC-SR04和LCD1602液晶显示屏&#xff0c;通过Proteus仿真平台实现超声波测距功能&#xff0c;并将测得的距离显示…

leetcode hot100

哈希 49.字母异位词分组 HashMap的含义比较晕&#xff0c;可以重做 双指针 11.盛最多水的容器 双指针的起始位置和移动条件没转过来&#xff0c;可以重做 15.三数之和 不太熟练&#xff0c;可以再做一遍 42.接雨水 还可以用dp和单调栈做 双指针法&#xff1a; 首先需要注意…

【DFS(深度优先搜索)详解】看这一篇就够啦

【DFS详解】看这一篇就够啦 &#x1f343;1. 算法思想&#x1f343;2. 三种枚举方式&#x1f343;2.1 指数型枚举&#x1f343;2.2 排列型枚举&#x1f343;2.3 组合型枚举 &#x1f343;3. 剪枝优化&#x1f343;4. 图的搜索&#x1f343;5. 来几道题试试手&#x1f343;5.1 选…

spark任务,使用 repartition 对数据进行了重新分区,但任务输入数据大小仍存在不均衡

目录 目录 确认 Spark 任务重新分区后的数据不均衡 1. 检查分区大小 2. 使用 DataFrame API 检查分区 3. 使用 Spark UI 查看分区情况 4. 使用日志记录分区信息 可能原因 1. 数据分布不均衡 2. 分区策略 3. 数据预处理 解决方案 1. 检查数据分布 2. 使用 coalesce…

代码随想录算法训练营Day62|冗余连接、冗余连接II

冗余连接 108. 冗余连接 (kamacoder.com) 考虑使用并查集&#xff0c;逐次将s、t加入并查集中&#xff0c;当发现并查集中find(u)和find(v)相同时&#xff0c;输出u和v&#xff0c;表示删除的边即可。 #include <iostream> #include <vector> using namespace s…

【分布式系统】注册中心Zookeeper

目录 一.Zookkeeper 概述 1.Zookkeeper 定义 2.Zookkeeper 工作机制 3.Zookkeeper 特点 4.Zookkeeper 数据结构 5.Zookkeeper 应用场景 统一命名服务 统一配置管理 统一集群管理 服务器动态上下线 软负载均衡 6.Zookkeeper 选举机制 第一次启动选举机制 非第一次…

uboot镜像之boot烧写

适用场景:单板上没有boot&#xff0c;和按地址烧写配合&#xff0c;可完成单板所有镜像的烧写。 原理:bootrom读取u-boot.bin至内存并执行此u-boot 然后运行uboot,通过uboot sf命令烧录uboot.bin到flash存储空间去. bootrom读取u-boot.bin至内存并执行此u-boot 通过uboot sf命…

【开发工具】webStrom2024版-插件

Chinese (Simplified) Language Pack / 中文语言包 英文界面变为中文界面。 Material Theme UI 界面美化 Rainbow Brackets 代码量变大时&#xff0c;总会伴随着各种括号&#xff1b;它能将括号赋予不同的颜色&#xff0c;方便我们区分。 Translation 中英互译&#xff0c;…

Codeforces Round 918 (Div. 4)(A~F)

目录 A. Odd One Out B. Not Quite Latin Square C. Can I Square? D. Unnatural Language Processing E. Romantic Glasses F. Greetings A. Odd One Out Problem - A - Codeforces 输出一个不同于其他两个数的数&#xff0c;用异或操作可以轻松解决。 void solve{int…