4个有趣且实用的Python脚本!超硬核!

在Python编程的世界中,掌握一些经典的、实用的脚本是每个开发者进阶之路上不可或缺的一步。

这里笔者与大家分享4个有趣且实用的Python脚本!

1. 彩色图像转黑白图像(批量操作)

该脚本展示了如何从当前目录下读取所有.jpg和.png文件并将其转换为黑白图像。如果你想批量转换指定目录下的所有图片,只需修改os.listdir(‘.’)为你需要的目录路径即可。

from PIL import Image
import os

def convert_to_grayscale(image_path):
    # 打开图片
    img = Image.open(image_path)

    # 转换为灰度模式(黑白)
    grayscale_img = img.convert('L')

    # 保存新的黑白图像
    output_filename = os.path.splitext(image_path)[0] + '_gray.png'  # 添加_gray后缀以区分原图
    grayscale_img.save(output_filename)

# 遍历当前目录下的所有.jpg和.png文件
for filename in os.listdir('.'):
    if filename.endswith(('.jpg', '.png')):
        image_path = os.path.join('.', filename)
        convert_to_grayscale(image_path)

2. 计算你的年龄

该脚本展示了如何计算并显示你的年龄的年数、月数和天数。

# Python 脚本:计算用户年龄的精确年数、月数和天数
```python
import time
from calendar import isleap

# 判断闰年函数
def is_leap_year(year):
    """
    接收一个整数年份作为参数,判断该年是否为闰年并返回布尔值。
    """
    return isleap(year)

# 返回指定月份天数的函数
def days_in_month(month, leap_year):
    """
    接收一个整数月份(1-12)和一个布尔值(表示当年是否为闰年),
    返回该月份的天数。
    """
    if month in [1, 3, 5, 7, 8, 10, 12]:
        return 31
    elif month in [4, 6, 9, 11]:
        return 30
    elif month == 2 and leap_year:
        return 29
    elif month == 2 and not leap_year:
        return 28

# 获取当前时间信息
current_time = time.localtime(time.time())

# 获取用户输入
name = input("请输入您的姓名: ")
age = int(input("请输入您的年龄: "))

# 计算用户的出生年份
birth_year = current_time.tm_year - age

# 初始化计算总天数
total_days = 0

# 计算从出生年份到当前年份的所有天数
for year in range(birth_year, current_time.tm_year + 1):
    # 根据年份判断是否为闰年,并累加相应的天数
    total_days += 366 if is_leap_year(year) else 365

# 计算从出生年份到当前月份的所有额外天数
for month in range(1, current_time.tm_mon):
    # 判断对应年份是否为闰年,获取该月天数并累加
    leap_status = is_leap_year(current_time.tm_year) if month <= current_time.tm_mon else is_leap_year(current_time.tm_year - 1)
    total_days += days_in_month(month, leap_status)

# 累加当前日期天数
total_days += current_time.tm_mday

# 输出结果
print(f"{name} 的年龄是 {age} 年或 {current_time.tm_mon} 个月或 {total_days} 天")

3. JSON转CSV

该脚本展示了如何从JSON文件中提取数据,并将其转换成CSV文件。

# 导入Python的json模块,用于处理JSON数据
import json

# 判断是否为脚本主入口
if __name__ == '__main__':
    try:
        # 读取JSON文件,并将其内容转换为Python对象(这里是一个列表,其中每个元素是字典)
        with open('input.json', 'r') as f:
            data = json.loads(f.read())

        # 初始化输出字符串,将第一个字典的所有键按逗号分隔拼接成CSV表头
        output = ','.join([*data[0].keys()])

        # 遍历JSON数据中的每个字典对象
        for obj in data:
            # 拼接每条记录的值,按照指定顺序("Name", "age", "birthyear")与逗号分隔写入一行
            output += f'\n{obj["Name"]},{obj["age"]},{obj["birthyear"]}'

        # 打开名为 'output.csv' 的文件进行写操作,并将处理好的CSV格式数据写入文件
        with open('output.csv', 'w') as f:
            f.write(output)

    except Exception as ex:  # 如果在执行过程中出现任何异常
        # 输出错误信息,包含具体的异常描述
        print(f'Error: {str(ex)}')

4. 低电量通知

该脚本展示了如何获取设备系统电池信息,然后检查电池电量百分比是否低于30%且未连接电源。如果满足这两个条件,则会发送一个桌面通知提醒用户。

import psutil

# 获取电池信息
battery = psutil.sensors_battery()
plugged = battery.power_plugged
percent = battery.percent

# 检查电池电量并发送通知(在电量低于30%且未插电源时)
if percent <= 30 and not plugged:
    # 对于Linux环境或跨平台通知可以使用pynotifier
    try:
        from pynotifier import Notification

        Notification(
            title="Battery Low",
            description=str(percent) + "% Battery remain!!",
            duration=5,  # Duration in seconds
        ).send()
    except ImportError:
        print("pynotifier is not installed. Install it first.")

    # 对于Windows环境,请确保已经安装了win10toast,并使用它来发送通知
    try:
        from win10toast import ToastNotifier

        toaster = ToastNotifier()
        toaster.show_toast(
            "Battery Low",
            str(percent) + "% Battery remain!!",
            duration=5,
            threaded=True
        )
    except ImportError:
        print("win10toast is not installed. Install it first.")

关于Python学习指南

学好 Python 不论是就业还是做副业赚钱都不错,但要学会 Python 还是要有一个学习规划。最后给大家分享一份全套的 Python 学习资料,给那些想学习 Python 的小伙伴们一点帮助!

包括:Python激活码+安装包、Python web开发,Python爬虫,Python数据分析,人工智能、自动化办公等学习教程。带你从零基础系统性的学好Python!

👉Python所有方向的学习路线👈

Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。(全套教程文末领取)

在这里插入图片描述

👉Python学习视频600合集👈

观看零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

在这里插入图片描述

温馨提示:篇幅有限,已打包文件夹,获取方式在:文末

👉Python70个实战练手案例&源码👈

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

在这里插入图片描述

👉Python大厂面试资料👈

我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

在这里插入图片描述

👉Python副业兼职路线&方法👈

学好 Python 不论是就业还是做副业赚钱都不错,但要学会兼职接单还是要有一个学习规划。

在这里插入图片描述

👉 这份完整版的Python全套学习资料已经上传,朋友们如果需要可以扫描下方CSDN官方认证二维码或者点击链接免费领取保证100%免费

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值