​十个常见的 Python 脚本 (详细介绍 + 代码举例)

简介: ​十个常见的 Python 脚本 (详细介绍 + 代码举例)

1. 批量重命名文件

介绍:  该脚本用于批量重命名指定目录下的文件,例如将所有 ".txt" 文件重命名为 ".md" 文件。

import os
 
def batch_rename(directory, old_ext, new_ext):
  """批量重命名文件扩展名。
  Args:
    directory: 要处理的目录路径。
    old_ext: 要替换的旧扩展名。
    new_ext: 要替换的新扩展名。
  """
 
  for filename in os.listdir(directory):
    if filename.endswith(old_ext):
      base_name = os.path.splitext(filename)[0]
      new_filename = base_name + new_ext
      old_path = os.path.join(directory, filename)
      new_path = os.path.join(directory, new_filename)
      os.rename(old_path, new_path)
 
# 示例用法:将当前目录下所有 ".txt" 文件重命名为 ".md" 文件
batch_rename(".", ".txt", ".md")

2. 下载网页图片

介绍:  该脚本用于下载指定网页上的所有图片,并保存到本地目录。

import requests
from bs4 import BeautifulSoup
import os
 
def download_images(url, save_dir):
  """下载网页上的所有图片。
  Args:
    url: 要下载图片的网页地址。
    save_dir: 保存图片的目录路径。
  """
 
  response = requests.get(url)
  soup = BeautifulSoup(response.text, 'html.parser')
 
  # 创建保存目录
  if not os.path.exists(save_dir):
    os.makedirs(save_dir)
 
  # 找到所有图片标签
  img_tags = soup.find_all('img')
 
  # 下载每张图片
  for i, img_tag in enumerate(img_tags):
    img_url = img_tag.get('src')
    if img_url:
      img_data = requests.get(img_url).content
      img_name = f"image_{i+1}.jpg"
      img_path = os.path.join(save_dir, img_name)
      with open(img_path, 'wb') as f:
        f.write(img_data)
      print(f"Downloaded: {img_name}")
 
# 示例用法:下载百度首页的图片
download_images("https://www.baidu.com", "baidu_images")

3. 发送邮件通知

介绍: 该脚本用于发送邮件通知,例如在脚本执行完毕后发送邮件通知管理员。

import smtplib
from email.mime.text import MIMEText
 
def send_email(sender_email, sender_password, receiver_email, subject, message):
  """发送邮件通知。
  Args:
    sender_email: 发送方邮箱地址。
    sender_password: 发送方邮箱密码。
    receiver_email: 接收方邮箱地址。
    subject: 邮件主题。
    message: 邮件内容。
  """
 
  msg = MIMEText(message, 'plain', 'utf-8')
  msg['Subject'] = subject
  msg['From'] = sender_email
  msg['To'] = receiver_email
 
  try:
    with smtplib.SMTP_SSL('smtp.gmail.com', 465) as smtp:
      smtp.login(sender_email, sender_password)
      smtp.send_message(msg)
    print("邮件发送成功!")
  except Exception as e:
    print(f"邮件发送失败:{e}")
 
# 示例用法:发送邮件通知
send_email("your_email@gmail.com", "your_password", "receiver@example.com", "脚本执行完毕", "脚本已成功执行!")

4. 读取 CSV 文件

介绍: 该脚本用于读取 CSV 文件,并可以根据需要对数据进行处理和分析。

import csv
 
def read_csv(file_path):
  """读取 CSV 文件。
  Args:
    file_path: CSV 文件路径。
  """
 
  with open(file_path, 'r', encoding='utf-8') as f:
    reader = csv.reader(f)
    # 跳过标题行
    next(reader)
    for row in reader:
      print(row)
 
# 示例用法:读取名为 "data.csv" 的 CSV 文件
read_csv("data.csv")

5. 写入 CSV 文件

介绍:  该脚本用于将数据写入 CSV 文件,可以用于数据存储和导出。

import csv
 
def write_csv(file_path, data):
  """将数据写入 CSV 文件。
  Args:
    file_path: CSV 文件路径。
    data: 要写入的数据,格式为列表的列表。
  """
 
  with open(file_path, 'w', encoding='utf-8', newline='') as f:
    writer = csv.writer(f)
    writer.writerows(data)
 
# 示例用法:将数据写入名为 "data.csv" 的 CSV 文件
data = [
  ["Name", "Age", "City"],
  ["Alice", 25, "New York"],
  ["Bob", 30, "London"],
]
write_csv("data.csv", data)

6. 网页数据

介绍:  该脚本用于网页数据,例如新闻标题、商品价格等,并可以将数据保存到本地或数据库。

import requests
from bs4 import BeautifulSoup
 
def scrape_website(url):
  """爬取网页数据。
  Args:
    url: 要爬取数据的网页地址。
  """
 
  response = requests.get(url)
  soup = BeautifulSoup(response.text, 'html.parser')
 
  # 提取数据,例如新闻标题
  titles = [title.text.strip() for title in soup.find_all('h2', class_='news-title')]
 
  # 打印提取的数据
  for title in titles:
    print(title)
 
# 示例用法:爬取新浪新闻首页的新闻标题
scrape_website("https://news.sina.com.cn/")

7. 自动化测试

介绍:  该脚本用于自动化测试软件或网站的功能,例如登录测试、表单提交测试等。

from selenium import webdriver
 
def test_login(url, username, password):
  """测试网站登录功能。
  Args:
    url: 要测试的网站地址。
    username: 登录用户名。
    password: 登录密码。
  """
 
  driver = webdriver.Chrome()
  driver.get(url)
 
  # 找到用户名和密码输入框,并输入用户名和密码
  username_input = driver.find_element_by_id("username")
  password_input = driver.find_element_by_id("password")
  username_input.send_keys(username)
  password_input.send_keys(password)
 
  # 找到登录按钮,并点击
  login_button = driver.find_element_by_id("login-button")
  login_button.click()
 
  # 检查是否登录成功
  if driver.current_url == "https://www.example.com/dashboard":
    print("登录成功!")
  else:
    print("登录失败!")
 
  driver.quit()
 
# 示例用法:测试 example.com 网站的登录功能
test_login("https://www.example.com/login", "testuser", "testpassword")

8. 图像处理

介绍:  该脚本用于图像处理,例如裁剪、缩放、添加水印等。

from PIL import Image
 
def resize_image(image_path, width, height):
  """缩放图片大小。
  Args:
    image_path: 图片路径。
    width: 新的宽度。
    height: 新的高度。
  """
 
  img = Image.open(image_path)
  img = img.resize((width, height))
  img.save("resized_" + image_path)
 
# 示例用法:将图片 "image.jpg" 缩放为 200x200 像素
resize_image("image.jpg", 200, 200)

9. 数据可视化

介绍:  该脚本用于数据可视化,例如绘制图表、生成报表等,可以更直观地展示数据。

import matplotlib.pyplot as plt
 
def plot_chart(x, y):
  """绘制折线图。
  Args:
    x: x 轴数据。
    y: y 轴数据。
  """
 
  plt.plot(x, y)
  plt.xlabel("X 轴")
  plt.ylabel("Y 轴")
  plt.title("折线图")
  plt.show()
 
# 示例用法:绘制 x=[1,2,3], y=[4,5,6] 的折线图
plot_chart([1, 2, 3], [4, 5, 6])

10. 创建简单的 Web 应用

介绍:  该脚本使用 Flask 框架创建一个简单的 Web 应用,例如显示 "Hello, world!" 的页面。

from flask import Flask
 
app = Flask(__name__)
 
@app.route("/")
def hello():
  return "Hello, world!"
 
if __name__ == "__main__":
  app.run(debug=True)

注意:  以上代码示例仅供参考,实际应用中需要根据具体需求进行修改和完善。部署爬虫相关代码需要遵守 robots 协议, 并注意数据安全。

如果对你有帮助,记得点赞分享支持一下~

相关文章
|
8天前
|
缓存 监控 测试技术
Python中的装饰器:功能扩展与代码复用的利器###
本文深入探讨了Python中装饰器的概念、实现机制及其在实际开发中的应用价值。通过生动的实例和详尽的解释,文章展示了装饰器如何增强函数功能、提升代码可读性和维护性,并鼓励读者在项目中灵活运用这一强大的语言特性。 ###
|
11天前
|
缓存 开发者 Python
探索Python中的装饰器:简化代码,增强功能
【10月更文挑战第35天】装饰器在Python中是一种强大的工具,它允许开发者在不修改原有函数代码的情况下增加额外的功能。本文旨在通过简明的语言和实际的编码示例,带领读者理解装饰器的概念、用法及其在实际编程场景中的应用,从而提升代码的可读性和复用性。
|
7天前
|
Python
探索Python中的装饰器:简化代码,提升效率
【10月更文挑战第39天】在编程的世界中,我们总是在寻找使代码更简洁、更高效的方法。Python的装饰器提供了一种强大的工具,能够让我们做到这一点。本文将深入探讨装饰器的基本概念,展示如何通过它们来增强函数的功能,同时保持代码的整洁性。我们将从基础开始,逐步深入到装饰器的高级用法,让你了解如何利用这一特性来优化你的Python代码。准备好让你的代码变得更加优雅和强大了吗?让我们开始吧!
15 1
|
12天前
|
设计模式 缓存 监控
Python中的装饰器:代码的魔法增强剂
在Python编程中,装饰器是一种强大而灵活的工具,它允许程序员在不修改函数或方法源代码的情况下增加额外的功能。本文将探讨装饰器的定义、工作原理以及如何通过自定义和标准库中的装饰器来优化代码结构和提高开发效率。通过实例演示,我们将深入了解装饰器的应用,包括日志记录、性能测量、事务处理等常见场景。此外,我们还将讨论装饰器的高级用法,如带参数的装饰器和类装饰器,为读者提供全面的装饰器使用指南。
|
8天前
|
存储 Python
Python自动化脚本编写指南
【10月更文挑战第38天】本文旨在为初学者提供一条清晰的路径,通过Python实现日常任务的自动化。我们将从基础语法讲起,逐步引导读者理解如何将代码块组合成有效脚本,并探讨常见错误及调试技巧。文章不仅涉及理论知识,还包括实际案例分析,帮助读者快速入门并提升编程能力。
33 2
|
8天前
|
存储 缓存 监控
掌握Python装饰器:提升代码复用性与可读性的利器
在本文中,我们将深入探讨Python装饰器的概念、工作原理以及如何有效地应用它们来增强代码的可读性和复用性。不同于传统的函数调用,装饰器提供了一种优雅的方式来修改或扩展函数的行为,而无需直接修改原始函数代码。通过实际示例和应用场景分析,本文旨在帮助读者理解装饰器的实用性,并鼓励在日常编程实践中灵活运用这一强大特性。
|
10天前
|
运维 监控 Python
自动化运维:使用Python脚本简化日常任务
【10月更文挑战第36天】在数字化时代,运维工作的效率和准确性成为企业竞争力的关键。本文将介绍如何通过编写Python脚本来自动化日常的运维任务,不仅提高工作效率,还能降低人为错误的风险。从基础的文件操作到进阶的网络管理,我们将一步步展示Python在自动化运维中的应用,并分享实用的代码示例,帮助读者快速掌握自动化运维的核心技能。
25 3
|
12天前
|
存储 算法 搜索推荐
Python高手必备!揭秘图(Graph)的N种风骚表示法,让你的代码瞬间高大上
在Python中,图作为重要的数据结构,广泛应用于社交网络分析、路径查找等领域。本文介绍四种图的表示方法:邻接矩阵、邻接表、边列表和邻接集。每种方法都有其特点和适用场景,掌握它们能提升代码效率和可读性,让你在项目中脱颖而出。
26 5
|
10天前
|
机器学习/深度学习 数据采集 人工智能
探索机器学习:从理论到Python代码实践
【10月更文挑战第36天】本文将深入浅出地介绍机器学习的基本概念、主要算法及其在Python中的实现。我们将通过实际案例,展示如何使用scikit-learn库进行数据预处理、模型选择和参数调优。无论你是初学者还是有一定基础的开发者,都能从中获得启发和实践指导。
24 2
|
12天前
|
数据库 Python
异步编程不再难!Python asyncio库实战,让你的代码流畅如丝!
在编程中,随着应用复杂度的提升,对并发和异步处理的需求日益增长。Python的asyncio库通过async和await关键字,简化了异步编程,使其变得流畅高效。本文将通过实战示例,介绍异步编程的基本概念、如何使用asyncio编写异步代码以及处理多个异步任务的方法,帮助你掌握异步编程技巧,提高代码性能。
48 4