Python通过模块化开发优化代码的技巧分享

2025-04-09 16:50

本文主要是介绍Python通过模块化开发优化代码的技巧分享,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧...

写个项目,文件夹里 .py 文件堆成山,变量名取到怀疑人生,函数到处复制粘贴,代码改一次崩三回……每次打开项目,内心就一个感受——“这都啥玩意儿?” 

放心,咱今天就来聊聊如何用模块化开发,拯救你的代码,让它井井有条、优雅可读,从此告别“屎山”!

什么是模块化开发

简单来说,模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分。就像搭乐高一样,把不同的功能拆成一个个小块,随用随取,既不浪费时间,也不让代码乱成一锅粥。

python 里,模块(module) 就是一个 .py 文件,里面可以定义函数、类、变量,还可以包含可执行代码。多个模块可以组成包(package),多个包再组成一个完整的项目。

比喻一下:

  • 模块(module)= 乐高积木
  • 包(package)= 一套乐高玩具
  • 项目 = 拼好的乐高城堡 

说了这么多,咱直接上代码,看看到底怎么玩!

如何拆分代码

假设我们要写一个简单的计算器,支持加减乘除。一般人可能会直接在 calculator.py 里写一堆函数:

# calculator.py
def add(a, b):
    return a + b

def subtract(a, b):
    return a - b

def multiply(a, b):
    return a * b

def divide(a, b):
    if b == 0:
        raise ValueError("除数不能为0!")
    return a / b

这么写倒也行,但问题来了

  • 如果以后还要加新功能,比如平方、开根号,这个文件会越来越长。
  • 代码全堆在一个 .py 里,复用性差,逻辑混乱。
  • 别人(包括未来的自己)接手这段代码时,容易迷失在一堆函数里。

改进版:拆分成javascript模块

我们可以把不同功能拆分到不同的文件里,比如这样:

calculator/
│── operations/
│   │── __init__.py
│   │── add.py
│   │── subtract.py
│   │── multiply.py
│   │── divide.py
│── main.py

然后,每个文件只处理自己的功能:

# operations/add.py
def add(a, b):
    return a + b
# operations/divide.py
def divide(a, b):
    if b == 0:
        raise ValueError("除数不能为0!")
    return a / b

最后,在 main.py 里这样用:

from operations.add import add
from operations.divide import divide

print(add(10, 5))  # 15
print(divide(10, 2))  # 5.0

优点:

结构清晰:每个功能各司其职,文件夹一目了然。

易维护:以后加新功能,直接加新模块,互不影响。

可复用:不同项目里可以直接复用这些模块。

细节提示

  • __init__.py 的作用是把 operations/ 变成一个 Python ,这样我们才能用 from operations.add import add 这样的方式导入。
  • 模块的命名尽量简洁有意义,比如 add.py 而不是 this_is_add_function.py文件名太长会让导入变得痛苦 

让模块更强大:使用 __init__.py

有时候,我们不想每次都 from operations.add import add,希望直接 from operations import add,那就要利用 __init__.py

# operations/__init__.py
from .add import add
from .subtract import subtract
from .multiply import multiply
from .divide import divide

这样,我们就可以一次性导入所有操作:

frompython operations import add, divide

pChina编程rint(add(10, 5))  # 15
print(divide(10, 2))  # 5.0

很多 Python 开发者容易忽视的一点

如果 __init__.py不写任何内容,那 from operations import add 是会报错的,因为 Python 不知道 operations 这个包里有哪些东西能被导入。

你一定会遇到的问题

模块导入失败?ModuleNotFoundError

ModuleNotFoundError: No module named 'operations'

解决方案

确保你在正确的目python录下运行 main.py,不能在 operations/ 里运行。

main.py 开头加上:

import sys
sys.path.append(".")  # 确保 Python 知道当前目录

import * 为什么不推荐

有人喜欢这样写:

from operations import *

看似很方便,但这其实是个坑,因为:

  • 你不知道具体导入了哪些东西,可能会覆盖已有的变量。
  • 代码可读性变差,别人(包括未来的你)会一脸懵逼。
  • __init__.py 里没 __all__ 的话,这种方式甚至会报错。

所以,建议明确导入所需模块,比如:

from operations import add, divide  # 一目了然

总结

  • 模块化开发能让代码更清晰、可复用、易维护,是写好 Python 代码的必备技能!
  • 一个 .py 文件就是一个模块,多个模块组成包(package)。
  • __init__.py 可以帮助管理包的导入,但用法要注意。
  • 避免 import *,尽量使用显式导入,代码更可读。

到此这篇关于Python通过模块化开发优化代码的技巧分享的文章就介绍到这了,更多相关Python模块化开发内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Python通过模块化开发优化代码的技巧分享的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154148

相关文章

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

Python Web框架Flask、Streamlit、FastAPI示例详解

《PythonWeb框架Flask、Streamlit、FastAPI示例详解》本文对比分析了Flask、Streamlit和FastAPI三大PythonWeb框架:Flask轻量灵活适合传统应用... 目录概述Flask详解Flask简介安装和基础配置核心概念路由和视图模板系统数据库集成实际示例Stre

游戏闪退弹窗提示找不到storm.dll文件怎么办? Stormdll文件损坏修复技巧

《游戏闪退弹窗提示找不到storm.dll文件怎么办?Stormdll文件损坏修复技巧》DLL文件丢失或损坏会导致软件无法正常运行,例如我们在电脑上运行软件或游戏时会得到以下提示:storm.dll... 很多玩家在打开游戏时,突然弹出“找不到storm.dll文件”的提示框,随后游戏直接闪退,这通常是由于

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at