程序员文章、书籍推荐和程序员创业信息与资源分享平台

网站首页 > 技术文章 正文

用Python开发日常小软件,让生活与工作更高效!附实例代码

hfteth 2025-05-22 10:31:39 技术文章 3 ℃

引言:Python如何让生活更轻松?

在数字化时代,编程早已不是程序员的专属技能。Python凭借其简洁易学的特点,成为普通人提升效率、解决日常问题的得力工具。无论是自动化重复任务、处理数据,还是开发个性化小工具,Python都能让你“事半功倍”。本文将通过几个实用案例,带你看清Python如何让生活与工作更高效!

一、自动化办公:告别繁琐,解放双手

案例1:自动发送邮件提醒

痛点:每天需要手动发送报告、提醒同事或客户?

解决方案:用Python的`smtplib`和`email`库实现定时邮件发送。

**代码示例**:

```python

import smtplib

from email.mime.text import MIMEText

from email.header import Header

import schedule

import time


def send_email():

sender = 'your_email@example.com'

receivers = ['client@example.com']

message = MIMEText('这是您的日报,请查收!', 'plain', 'utf-8')

message['From'] = Header("自动化助手", 'utf-8')

message['To'] = Header("客户", 'utf-8')

message['Subject'] = Header("日报提醒", 'utf-8')


try:

smtp_obj = smtplib.SMTP('smtp.example.com', 587)

smtp_obj.starttls()

smtp_obj.login(sender, 'your_password')

smtp_obj.sendmail(sender, receivers, message.as_string())

print("邮件发送成功")

except Exception as e:

print(f"发送失败:{e}")


# 每天上午10点执行

schedule.every().day.at("10:00").do(send_email)


while True:

schedule.run_pending()

time.sleep(1)

```

效果:设置后,程序会定时发送邮件,省去手动操作的麻烦。

案例2:Excel数据自动处理

痛点:每月整理销售数据,手动汇总耗时费力?

解决方案:用`pandas`库读取Excel文件,自动计算销售额、生成图表。

**代码示例**:

```python

import pandas as pd


# 读取Excel文件

df = pd.read_excel('sales_data.xlsx')


# 计算总销售额

total_sales = df['销售额'].sum()

print(f"本月总销售额:{total_sales}元")


# 按地区分组统计

region_sales = df.groupby('地区')['销售额'].sum()

print(region_sales)


# 保存结果到新Excel

df.to_excel('processed_sales.xlsx', index=False)

```

效果:几行代码即可完成数据清洗与分析,效率提升数倍!

二、数据处理与爬虫:挖掘信息,驱动决策

案例3:爬取天气数据并生成提醒

痛点:每天手动查看天气预报太麻烦?

解决方案:用`requests`和`BeautifulSoup`爬取天气网数据,结合`win10toast`发送桌面提醒。

**代码示例**:

```python

import requests

from bs4 import BeautifulSoup

from win10toast import ToastNotifier

import time


def get_weather():

url = "https://www.weather.com.cn/weather/101010100.shtml"

response = requests.get(url)

soup = BeautifulSoup(response.content, 'html.parser')

weather = soup.find('p', class_='wea').text

temp = soup.find('span', class_='tmp').text

return f"今日天气:{weather},温度:{temp}"


def send_notification(message):

toaster = ToastNotifier()

toaster.show_toast("天气提醒", message, duration=10)


if __name__ == "__main__":

while True:

weather_info = get_weather()

send_notification(weather_info)

time.sleep(86400) # 每天执行一次

```

**效果**:每天自动获取天气信息并推送,再也不怕忘记带伞!

三、实用小工具:解决生活中的小烦恼

案例4:二维码生成器

痛点:需要频繁生成二维码(如名片、活动海报)?

解决方案:用`qrcode`库快速生成二维码图片。

**代码示例**:

```python

import qrcode


def generate_qr(content, filename):

qr = qrcode.QRCode(

version=1,

error_correction=qrcode.constants.ERROR_CORRECT_L,

box_size=10,

border=4,

)

qr.add_data(content)

qr.make(fit=True)


img = qr.make_image(fill_color="black", back_color="white")

img.save(filename)


# 生成包含个人微信的二维码

generate_qr("https://weixin.qq.com/g/A1B2C3D4", "wechat_qr.png")

```

效果:一键生成二维码,适合分享链接或制作电子名片。

案例5:快递单号批量查询

痛点:双十一后,手动查询多个快递单号太费时?

解决方案:用`requests`和`正则表达式`批量查询快递状态。

**代码示例**:

```python

import requests

import re


def query_express(tracking_number):

url = f"https://www.kuaidi100.com/query?type=zhongtong&postid={tracking_number}"

response = requests.get(url)

status = re.search(r'"state":"(.*?)",', response.text).group(1)

return f"单号:{tracking_number},状态:{status}"


# 批量查询多个单号

tracking_numbers = ["1234567890", "0987654321"]

for number in tracking_numbers:

print(query_express(number))

```

效果:输入单号列表,即可批量获取快递状态,省时省力!

四、结语:Python,让生活更智能

从自动化办公到数据处理,再到个性化工具开发,Python的灵活性和丰富的库支持让它成为“效率神器”。无论是职场新人还是家庭主妇,只要掌握基础语法和几个关键库(如`pandas`、`requests`、`tkinter`),就能快速开发出实用工具。

行动建议:

1. 从简单项目入手(如定时提醒、Excel自动化)。

2. 参考GitHub或B站教程,学习完整项目(如爬虫、GUI应用)。

3. 结合个人需求,定制专属工具(如家庭预算管理、学习计划提醒)。

现在就开始动手吧!让Python成为你生活中的“数字助手”!

最近发表
标签列表