10个Python自动化日常任务实战脚本示例

news2024/12/25 15:32:27

小编准备入门了Python入门学习籽料+80个Python入门实例
点击 领取(无偿获得)

1. 自动备份文件夹

目标 : 每天自动将指定文件夹的内容备份到另一个位置。

import shutil  
import datetime  
  
def backup_files(source, destination):  
    """  
    备份函数,将source路径下的文件复制到destination。  
    """  
    # 创建当前日期时间的文件夹名称  
    timestamp = datetime.datetime.now().strftime('%Y%m%d%H%M%S')  
    backup_folder = f"{destination}/{timestamp}"  
      
    # 创建备份目录  
    shutil.makedirs(backup_folder, exist_ok=True)  
      
    # 复制文件  
    shutil.copytree(source, backup_folder)  
    print(f"备份完成至: {backup_folder}")  
  
# 示例用法  
source_folder = "/path/to/source"  
destination_folder = "/path/to/destination"  
backup_files(source_folder, destination_folder)  

解释 : 使用shutil.copytree来复制整个文件夹,datetime用于生成唯一的备份文件夹名。

2. 邮件提醒

目标 : 发送一封邮件提醒自己或他人。

import smtplib  
from email.mime.text import MIMEText  
from email.mime.multipart import MIMEMultipart  
  
def send_email(subject, body, to, sender="your_email@example.com", password="your_password"):  
    """  
    发送邮件的函数。  
    """  
    msg = MIMEMultipart()  
    msg['From'] = sender  
    msg['To'] = to  
    msg['Subject'] = subject  
      
    msg.attach(MIMEText(body, 'plain'))  
      
    server = smtplib.SMTP('smtp.example.com', 587)  # 用你的SMTP服务器和端口替换  
    server.starttls()  # 启用安全传输  
    server.login(sender, password)  
    text = msg.as_string()  
    server.sendmail(sender, to, text)  
    server.quit()  
      
# 示例用法  
send_email("任务提醒", "别忘了今天的会议!", "receiver@example.com")  

注意 : 需要替换SMTP服务器信息和认证信息。

3. 自动下载网页内容

目标 : 下载网页上的特定数据,如新闻文章。

import requests  
  
def download_web_content(url, filename):  
    """  
    下载网页内容并保存到文件。  
    """  
    response = requests.get(url)  
    if response.status_code == 200:  
        with open(filename, 'w', encoding='utf-8') as file:  
            file.write(response.text)  
        print(f"内容已保存至 {filename}")  
    else:  
        print("请求失败,状态码:", response.status_code)  
  
# 示例用法  
url = "https://news.example.com/article"  
download_web_content(url, "article.txt")  

4. 简易密码管理器

目标 : 存储和检索网站用户名和密码。

import json  
  
def save_credentials(site, username, password, filename="passwords.json"):  
    """  
    保存账号密码到JSON文件。  
    """  
    data = {site: {"username": username, "password": password}}  
    with open(filename, 'a+') as file:  
        file.seek(0)  # 移动到文件开头  
        try:  
            existing_data = json.load(file)  
            existing_data.update(data)  
            file.seek(0)  # 移动到文件开头准备重写  
            json.dump(existing_data, file, indent=4)  
        except json.JSONDecodeError:  
            json.dump(data, file, indent=4)  
  
def retrieve_credentials(site, filename="passwords.json"):  
    """  
    从文件中检索账号密码。  
    """  
    with open(filename, 'r') as file:  
        data = json.load(file)  
        return data.get(site, None)  
  
# 示例用法  
save_credentials("example.com", "user1", "pass123")  
print(retrieve_credentials("example.com"))  

5. 图片下载器

目标 : 根据URL列表下载图片。

import os  
import requests  
  
def download_images(urls, folder="images"):  
    """  
    下载图片并保存到指定文件夹。  
    """  
    if not os.path.exists(folder):  
        os.makedirs(folder)  
    for url in urls:  
        response = requests.get(url)  
        if response.status_code == 200:  
            filename = os.path.join(folder, url.split("/")[-1])  
            with open(filename, 'wb') as file:  
                file.write(response.content)  
            print(f"下载完成: {filename}")  
        else:  
            print(f"下载失败: {url}")  
  
# 示例URL列表  
urls = ["http://example.com/image1.jpg", "http://example.com/image2.jpg"]  
download_images(urls)  

6. 自动化Excel数据处理

目标 : 读取Excel数据,进行简单处理,然后保存。

import pandas as pd  
  
def process_excel(input_file, output_file):  
    """  
    读取Excel文件,添加一列当前日期,然后保存。  
    """  
    df = pd.read_excel(input_file)  
    df['Processed_Date'] = pd.Timestamp.now().date()  
    df.to_excel(output_file, index=False)  
    print(f"处理完成并保存至{output_file}")  
  
# 示例用法  
process_excel("data.xlsx", "processed_data.xlsx")  

7. 网络速度测试

目标 : 使用Python测试网络下载速度。

import speedtest  
  
def test_internet_speed():  
    """  
    测试并打印当前的互联网下载速度。  
    """  
    st = speedtest.Speedtest()  
    st.download()  
    speed = st.results.download / 1024 / 1024  # 转换为MB/s  
    print(f"当前下载速度: {speed:.2f} MB/s")  
  
test_internet_speed()  

8. 自动化社交媒体帖子发布

目标 : 在支持API的社交媒体平台(如Twitter)上自动发布帖子。

注意 : 实际应用需安装相关库(如tweepy),并获取API密钥。

# 假设使用tweepy库  
import tweepy  
  
def post_to_twitter(api_key, api_secret, access_token, access_token_secret, message):  
    """  
    使用Tweepy API发布推文。  
    """  
    auth = tweepy.OAuthHandler(api_key, api_secret)  
    auth.set_access_token(access_token, access_token_secret)  
    api = tweepy.API(auth)  
    api.update_status(message)  
    print("推文发布成功!")  
  
# 实际使用时需替换为真实密钥  
post_to_twitter("your_api_key", "your_api_secret", "your_access_token", "your_access_token_secret", "Hello, Twitter!")  

9. 电脑定时关机

目标 : 设置电脑在指定时间自动关机。

import os  
  
def set_shutdown(time_minutes):  
    """  
    设置电脑在多少分钟后关机。  
    """  
    os.system(f'shutdown /s /t {time_minutes*60}')  
    print(f"电脑将在{time_minutes}分钟后自动关机。")  
  
# 取消关机命令  
def cancel_shutdown():  
    """  
    取消已设置的关机计划。  
    """  
    os.system('shutdown /a')  
    print("关机计划已取消。")  
  
set_shutdown(15)  # 设置15分钟后关机  
# 若要取消,调用cancel_shutdown()  

10. 监控CPU使用率

目标 : 实时监控并打印CPU使用率。

import psutil  
  
def monitor_cpu_usage(interval=1):  
    """  
    每隔interval秒打印一次CPU使用率。  
    """  
    while True:  
        cpu_percent = psutil.cpu_percent(interval=interval)  
        print(f"CPU使用率: {cpu_percent}%")  
        # 暂停以便观察  
        time.sleep(interval)  
  
# 示例用法,每秒打印一次  
monitor_cpu_usage(1)  


进阶技巧与综合应用

综合案例:自动化报告生成

目标 : 结合上述技能,创建一个简单的报告,包括网络速度、CPU使用率统计,并通过邮件发送。

步骤1 : 获取网络速度

我们将使用之前定义的test_internet_speed函数来获取网络速度。

步骤2 : 监控CPU使用率并记录

为了简洁,我们不直接在此处运行长时间的CPU监控循环,而是模拟一个简单的CPU使用率数据收集过程。

# 模拟CPU使用率数据收集  
cpu_data = [psutil.cpu_percent(interval=1) for _ in range(5)]  # 收集5次数据  

步骤3 : 创建报告文本

def create_report(cpu_data, internet_speed):  
    """  
    创建报告文本。  
    """  
    report = f"### 自动化报告\n\n"  
    report += f"**网络速度** : {internet_speed:.2f} MB/s\n\n"  
    report += "## CPU使用率统计\n"  
    for i, usage in enumerate(cpu_data, start=1):  
        report += f"- 时间段{i}: {usage}%\n"  
    return report  
  
internet_speed = test_internet_speed()  # 实际获取网络速度  
report_text = create_report(cpu_data, internet_speed)  
print(report_text)  

步骤4 : 发送报告邮件

使用之前定义的send_email函数发送包含报告文本的邮件。

# 示例用法,发送报告邮件  
subject = "自动化监控报告"  
to = "receiver@example.com"  
send_email(subject, report_text, to)  

综合代码示例 :

# 假定所有必要的函数已经定义  
internet_speed = test_internet_speed()  
cpu_data = [psutil.cpu_percent(interval=1) for _ in range(5)]  
report_text = create_report(cpu_data, internet_speed)  
send_email("自动化监控报告", report_text, "receiver@example.com")  

好了,今天的分享就到这里了,我们下期见。如果本文对你有帮助,请动动你可爱的小手指点赞、转发、在看吧!

文末福利

公众号消息点击“联系我”添加小编微信(RainbowToLife)获取Python编程、人工智能、爬虫等100+本精品电子书。

Python代码/软件定制

需要定制Python代码或软件的小伙伴们,请后台留言,或者后台回复“联系我”微信联系。接单范围

python入门虽然简单,很多新手依然卡在基础安装阶段,大部分教程对一些基础内容都是一带而过,好多新手朋友,对一些基础知识常常一知半解,需要在网上查询很久。

扎实的基础知识,对之后的学习、工作都是非常必要的。从这400集的Python视频教程中由易到难,平常所有的疑难点都可以从中找到答案(比培训机构讲的都详细)。另外还配套Python中文手册这最基础的编程环境搭建就做了200多页的详细讲解!其他基础语法、函数、模块和包均一一精细解答。新手必备!

还分享Python 50G大礼包,里面还有Python面试真题,里面干货满满,一次全拿走!(点击即可获取)

1.Python大礼包

2.Python电子书

3.Python面试集锦

4.Python小白必备手册

5.Python安装包

6.数据分析全套资源

7.数据分析全套资源

最后由于文章篇幅有限,文档资料内容较多,需要这些文档的朋友,可以加小助手微信免费获取,【保证100%免费】,中国人不骗中国人。在这里插入图片描述

希望这篇文章对你有帮助,也希望能帮到大家,因为你我都是热爱python的编程语言爱好者。

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

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

相关文章

DevEcoStudio创建的默认工程HelloWorld build失败请问如何解决?

解决方法: 方法一: 方法二: 确认当前登录的windows用户是否是Administrator,出现这种情况,大概率都是普通用户,所以造成权限不足的问题。一种解决办法是切换到Administrator用户再打开项目进行build。 如…

已拿证 | 2024深圳驾考科目四全攻略:技巧、知识点一网打尽

目录 _head 精简500题 区分变道和左转,变道手下垂,左转手伸直 紧急包扎需要柔软介质 网状线内禁止停车 会车千万不能开远光灯 只准直行 城3公4 城5公7 一急二反三连续 落水救援 驾驶陋习 车到路肩人在外 交警先看脸!&#xff01…

Redis保姆级安装教程

下载:https://github.com/redis-windows/redis-windows/releases 然后就慢慢等待 下载完解压,打开 以管理员身份运行,这里一直按回车就可以了 复制路径 这里勾错了,是编辑 修改配置文件redis.conf 加这一行 以管理员身份运行cmd,输入redis-cli 在输入ping 再输入info 这样就完…

IP-RDS-222、IP-PRZ-59-AM12、EG-TRZ-42-L、EG-TRZ-42-H比例减压阀放大器

IP-DAR-250、IP-DAR-43C-L、IP-DAR-43C-H、IP-RDS-222、IP-PRZ-59-AM12、EG-TRZ-42-L、EG-TRZ-42-H比例减压阀 EE-PRB、EE-PRD比例压力阀 EE-P2G、ET-P2S、EB-P2A、EE-P2A、ET-P2A、EE-P2H、EG-F2A、EU-F2A比例流量阀 EF-F3G、EU-F3G比例压力补偿流量阀 EQ-S4M、EG-S4M、EQ…

【JAVA CORE_API】Day21 Map接口、在线聊天室v3.0、Java的反射机制(P1)

Map接口 Map接口 Map是Java中用于存储键值对(key-value pairs)的接口,每个键(key)对应一个值(value)。它不允许重复的键,但允许不同的键映射相同的值。 关键特点: 键值…

Linux 可视化管理工具:宝塔面板(BT)

😀前言 在 Linux 系统的运维管理中,命令行界面(CLI)是主要的操作方式。然而,对于许多系统管理员或开发者来说,使用 CLI 进行管理和维护任务并不总是最直观或最方便的方式。为了简化操作并提高效率&#xff…

【注解】反序列化时匹配多个 JSON 属性名 @JsonAlias 详解

JsonAlias 注解是 Jackson 提供的一个功能强大的注解,允许一个字段在反序列化时匹配多个 JSON 属性名。它适用于在处理多种输入数据格式时,或当 JSON 数据的键名可能变化时。 一、JsonAlias 的作用 多种别名:JsonAlias 允许你为一个字段定义…

利用深度学习技术来实现街景图像的语义分割(街景图像语义分割)

本项目致力于利用深度学习技术来实现街景图像的语义分割。通过精确地识别和分类图像中的每个像素,该技术能够自动划分出街道、人行道、车辆、行人等各种不同的物体类别。这在智能交通系统、自动驾驶、城市规划等领域有着广泛的应用前景。 技术实现 深度学习模型&am…

网站上线流程完全手册:域名、服务器与CDN

网站上线的核心要点 需要买域名 域名备案(国内) 买服务器 把服务器IP和域名(网址)绑定 把本地网站代码文件上传到服务器上 我来先来了解下以上的概念 域名介绍 域名是网站的地址,类似于你的家在街上的位置。它让人们通过简单的名字(如 www.baidu.…

大模型时代的AI应用开发,可以不用,但必须会

成熟的“格子衫”和年轻的“脸庞”,与开发者有关的大会总是少不了这两种元素,Create 2024百度AI开发者大会也不例外。 过去几十年,层出不穷的编程语言、框架等新技术,把一代又一代年轻的脸庞,塑造为成熟的格子衫&…

网络安全威胁2024年中报告

近日,奇安信威胁情报中心发布《网络安全威胁2024年中报告》,内容涵盖高级持续性威胁(APT)、勒索软件、互联网黑产、漏洞利用等几方面。 APT攻击活动:2024 年上半年,APT 攻击主要集中在信息技术、政府、科研…

设计模式笔记07(java版)

文章目录 迭代器模式定义结构优缺点使用场景迭代器模式在JDK源码中的使用 访问者模式定义结构案例实现优缺点使用场景扩展1. 分派:2. 动态分派:3. 静态分派:4. 双分派: 备忘录模式概述定义结构“黑箱”备忘录模式优缺点使用场景 解…

递归神经网络 (RNN) 简介

文章目录 一、介绍二、什么是递归神经网络 (RNN)?三、展开递归神经网络四、训练递归神经网络五、RNN 的类型六、现实生活中的 RNN 用例七、RNN 的两个主要限制八、RNN的变体8.1 双向递归神经网络 (BRNN)8.2 长短期记忆…

色彩的含义和使用色彩象征的艺术

无论你走到哪里,你都能看到颜色:天空中的白云,绿色的植被逐渐上升,灰色的石头结构和红砖建筑,在你脚下磨砺着棕色的土壤。你不只是看到这些颜色......你感觉到它们。 一,颜色的含义从何而来? 熟…

华为OD算法题整理目录

目录 专栏导读华为OD机试算法题太多了,知识点繁杂,如何刷题更有效率呢? 一、逻辑分析二、数据结构1、线性表① 数组② 双指针 2、map与list3、队列4、链表5、栈6、滑动窗口7、二叉树8、并查集9、矩阵 三、算法1、基础算法① 贪心思维② 二分查…

面试搜狐大模型算法工程师,体验真棒!!!

搜狐大模型算法工程师面试题 应聘岗位:搜狐大模型算法工程师 面试轮数: 整体面试感觉:偏简单 面试过程回顾 1. 自我介绍 在自我介绍环节,我清晰地阐述了个人基本信息、教育背景、工作经历和技能特长,展示了自信和沟通…

代码随想录算法训练营第 53 天 |卡码网110.字符串接龙 卡码网105.有向图的完全可达性 卡码网106.岛屿的周长

代码随想录算法训练营 Day53 代码随想录算法训练营第 53 天 |卡码网110.字符串接龙 卡码网105.有向图的完全可达性 卡码网106.岛屿的周长 目录 代码随想录算法训练营前言卡码网110.字符串接龙卡码网105.有向图的完全可达性卡码网106.岛屿的周长 一、卡码网110.字符串接龙1.题…

Java:StringBuilder、StringBuffer、StringJoiner

文章目录 StringBuilder代码为什么操作字符串建议使用StringBuilder,而不是String?但String还是不可替代的 StringBuffer案例:接收字符串,返回String类型的[11,22]这种形式代码 StringJoiner上面那个案例,用StringJoiner的方法解决…

Linux服务器不能使用su切换到其他用户

1. 现象 使用非root用户登录系统后,想使用su - 切换到root时,输入正确的密码后出现: 一开始以为自己密码记错了,或者是系统被入侵后篡改了root用户密码,服务器上的数据非常重要。后面不通过SSH连接,直接去…

2024年AI最热门行业人才:计算机视觉与自然语言及语音处理设计开发工程师!

2024年,计算机视觉设计与开发工程师以及自然语言及语音处理设计与开发工程师将成为技术行业中的“超级明星”。无论是智能家居、自动驾驶汽车,还是医疗诊断、金融服务,AI已经深刻融入我们的日常生活,而这些领域的智能化转型都离不…