【Python】三、代码组织架构

0 序

我虽然没参加过比较大型的多人协作项目,但也独立开发过上万行的C++、Python项目,所以多少有些工程经验吧,在此不辞领教,分享下如何能开发一个结构清晰,代码易维护,鲁棒性强,功能扩展性强的工程。谈不上软件工程的理念,只是一些小问题上的代码开发技巧。

在第一节《Python基础》已经谈过代码风格规范、注释代码块、文档测试,都是项目开发维护很实用的技能,本篇不再重复阐述。

1 import与代码结构组织

1.1 包、模块命名

包(package)是指目录,导入包的时候实际是导入目录下的__init__.py文件。
模块(module)是指py文件,例如debuglib.py。由若干包和模块组成的特定功能或项目统称为“库”,Python自带可以直接引用的称为标准库(第一方库),其他组织发布的扩展,需要pip等额外安装后才能用的称为第三方库,公司内部开发的功能称为第二方库。

开发二方库时,包和模块命名必须遵循Python标识符规则。PEP8
模块应该用简短全小写的名字,如果为了提升可读性,下划线也是可以用的。Python包名也应该使用简短全小写的名字,但不建议用下划线。

个人经验:为了避免模块名和函数名混淆,我一般会在模块名后面统一加上lib,例如debug.py改为debuglib.py

1.2 import语法

关于Python包和模块的10个知识清单,常见导入语法:

import <package>  # 导入一个包
import <module>   # 导入一个模块
from <package> import <module or subpackage or object>  # 从一个包中导入模块/子包/对象
from <module> import <object>  # 从模块中导入对象

还可以在后缀添加as ...取别名简化引用,如:import pandas as pd

PEP8推荐以下导入顺序,并在每组之间插入一个空行:

  1. 标准库的导入
  2. 相关的第三方库导入
  3. 特定的本地应用/库导入

关于本地库的导入,Google开源项目风格指南推荐使用模块的全路径名来导入每个模块(使用这种全路径名做项目时,一定要注意1.5要讲到的"import时的加载顺序"问题,一般不在__init__.py写功能或者导包操作。):

# Reference in code with complete name.
import sound.effects.echo

# Reference in code with just module name (preferred).
from sound.effects import echo

为了使用完整路径,需要用setup.py安装库,或者将库配置到site-packages目录:
[外链图片转存失败(img-4UvyB7dS-1565057900636)(http://i4.fuimg.com/582188/f4048e807584c3ac.png)]

读者如果不知道要怎么写import,那么都按全路径名来写就对了,这样任何一个py文件都可以作为一个独立脚本文件来运行、测试,也不会遇到IDE的一些索引跳转到定义的功能bug。还有种比较常见的写法是在库的一些内部包里使用相对引用,这种写法就无法直接将build_main.py作为一个独立脚本来运行或测试了:
在这里插入图片描述

1.3 库的安装

如果希望自己的项目发送给别人时,能自动安装相关的三方库、二方库,可以参考该文:Python 打包分发工具 setuptools 简介

还有一种比较简单粗暴的方法,是在代码中使用try语法:

import subprocess

try:
    from bs4 import BeautifulSoup
except ModuleNotFoundError:
    subprocess.run(['pip3', 'install', 'BeautifulSoup'
  • 22
    点赞
  • 54
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
STDC是一种基于C语言标准库的模块架构,它的核心思想是将代码按照功能模块划分成多个小模块,每个小模块负责处理一个特定的功能,这些小模块可以独立编译、测试和部署。STDC的模块架构可以让开发者更加高效地组织代码,提高代码的可维护性和可重用性。 下面是一个简单的STDC模块架构的示例: ``` stdc/ ├── include/ │ ├── module1.h │ ├── module2.h │ ├── ... ├── src/ │ ├── module1.c │ ├── module2.c │ ├── ... ├── Makefile ├── README.md ``` 在这个示例中,`include`目录包含了所有模块的头文件,`src`目录包含了所有模块的源代码文件。`Makefile`文件用于编译和链接所有模块的代码,生成可执行文件或库文件。 下面是一个简单的STDC模块架构Python代码实现示例: ``` stdc/ ├── __init__.py ├── module1/ │ ├── __init__.py │ ├── module1.py ├── module2/ │ ├── __init__.py │ ├── module2.py ├── ... ``` 在这个示例中,STDC模块架构被用于Python代码组织。每个功能模块都被封装在一个独立的目录中,目录下包含了一个`__init__.py`文件和一个或多个Python代码文件。`__init__.py`文件用于定义模块的接口和导出需要暴露的函数和变量。 例如,`module1.py`文件可以定义一个名为`func1`的函数: ```python def func1(): print("This is module1's func1") ``` `__init__.py`文件可以将`func1`函数导出: ```python from .module1 import func1 ``` 这样,在其他Python模块中,可以使用以下语句导入`module1`模块并调用`func1`函数: ```python from stdc.module1 import func1 func1() ``` 总的来说,STDC模块架构的原理是将代码按照功能模块划分成多个小模块,每个小模块负责处理一个特定的功能,这些小模块可以独立编译、测试和部署。在Python中,可以通过创建独立的目录和`__init__.py`文件来实现STDC模块架构

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值