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

开发 前端
本文与大家分享四个有趣且实用的Python脚本!下面,我们一起来看!

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

这里笔者与大家分享四个有趣且实用的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 脚本:计算用户年龄的精确年数、月数和天数
```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.")

责任编辑:赵宁宁 来源: 数据科学与AI
相关推荐

2022-07-15 14:54:00

DockerLinux技巧

2017-07-10 14:00:04

Python命令行

2022-06-24 10:02:43

PythonShell脚本

2022-07-30 07:50:40

数据库字段存储

2023-10-26 07:24:19

ChatGPT聊天机器人信息

2022-10-10 23:19:02

Python脚本语言工具库

2022-03-21 08:00:00

网络安全影子IT数据泄露

2021-01-08 16:27:52

SQL数据库开发

2020-10-29 08:35:06

Pandas函数Python

2009-10-23 14:22:59

Windows 7微软隐藏功能

2011-08-29 18:37:47

Ubuntu11.04

2017-07-28 11:14:46

数据可视化界面设计

2024-04-10 07:49:37

React 19use 钩子Suspense

2024-01-26 09:01:30

HooksReact 19版本

2022-01-17 10:50:15

Python代码内存

2021-04-22 10:28:52

开发技能代码

2013-08-26 10:51:56

Web开发框架

2022-05-04 12:44:57

Python编程语言

2021-03-28 22:55:44

Python编程技术

2022-04-20 07:42:08

Python脚本代码
点赞
收藏

51CTO技术栈公众号