当前位置: 首页 > news >正文

Day 37 文件的规范拆分和写法

@浙大疏锦行

在不同的文件中导入其他目录的文件,核心在于了解导入方式和python解释器检索目录的方式。

如何把一个文件,拆分成多个具有着独立功能的文件,然后通过import的方式,来调用这些文件。这样具有几个好处:

1. 可以让项目文件变得更加规范和清晰

2. 可以让项目文件更加容易维护,修改某一个功能的时候,只需要修改一个文件,而不需要修改多个文件。

3. 文件变得更容易复用,部分通用的文件可以单独拿出来,进行其他项目的复用。

1.项目核心代码组织

2.配置文件管理

3.实验与探索代码

4.项目产出管理

注意事项

if name="main"

常常会看到if __name__ == "__main__"这个写法,实际上,每个文件都是一个对象,对象就会有属性和方法。

如果直接运行这个文件,则__name__等于__main__,若这个文件被其他模块导入,则__name__不等于__main__。

这个写法有如下好处:

1. 明确程序起点:一个 Python 项目往往由多个模块组成。if __name__ == "__main__" 可清晰界定程序执行的起始位置。比如一个包含数据处理模块 data_processing.py、模型训练模块 model_training.py 的机器学习项目,在 model_training.py 中用 if __name__ == "__main__" 包裹训练相关的主逻辑代码,运行该文件时就知道需要从这里开始执行(其他文件都是附属文件),让项目结构和执行流程更清晰。(大多时候如此)

2. 避免执行:python遵从模块导入即执行机制,当你使用 import xxx 导入一个模块时,Python 会执行该模块中的所有顶层代码(即不在任何函数或类内部的代码)。如果顶层代码中定义了全局变量或执行了某些操作(如读取文件、初始化数据库连接),这些操作会在导入时立即生效,并可能影响整个程序的状态。为了避免执行不必要的代码,我们可以使用 if __name__ == "__main__" 避免在导入时执行不必要的代码。这样,只有当模块被直接运行时(即被执行 python xxx.py),才会执行顶层代码,而导入时则不会执行。这样,我们就可以确保在导入模块时,不会执行不必要的代码,从而提高程序的性能和可维护性。

3. 合理的资源管理:if __name__ == "__main__" 与定义 main 函数结合使用,函数内变量在函数执行完这些变量被释放,能及时回收内存资源,避免内存泄漏,保证程序高效运行。

编码格式

规范的py文件,首行会有:# -- coding: utf-8 --

主要目的是 显式声明文件的编码格式,确保 Python 解释器能正确读取和解析文件中的非 ASCII 字符(如中文、日文、特殊符号等)。也就是说这个是写给解释器看的。

因为,在 Python 2.x 时代,默认编码是 ASCII,不支持直接在代码中写入非 ASCII 字符(如中文注释、字符串中的中文),否则会报错(SyntaxError: Non-UTF-8 code starting with...)。但是Python 3.x 默认为 UTF-8 编码,理论上可以省略编码声明。但实际开发中,为了兼容旧代码、明确文件编码规则,或在团队协作中避免因编辑器 / 环境配置不同导致的乱码问题,许多开发者仍会保留这一行声明。

ps:

1. 编码声明必须出现在文件的前两行(通常是首行),否则会被忽略。

2. 如果编码格式没问题,可能是vscode的编码格式不是utf-8,可以尝试修改编码格式。

3. 常见的编码报错是因为字符串编码问题,可以尝试显式转化,即读取的时候转化为utf-8编码。

非ASCII 字符的代码如下所示:

# -*- coding: utf-8 -*- msg = "你好,世界!" # 中文字符串 print(msg) #你好,世界!

很多时候,项目中会包含gitattribute文件,来确保在不同操作系统和编辑器中,文件的编码格式一致。

类型注解

Python 的类型注解是在 Python 3.5+ 引入的特性,用于为变量、函数参数、返回值和类属性等添加类型信息。虽然 Python 仍是动态类型语言,但类型注解可以提高代码可读性、可维护性,并支持静态类型检查工具(如 mypy)。

其次你在安装python插件的时候,附带安装了2个插件

1. 一个是python debugger用于断点调试,我们已经介绍了

2. 另一个是pylance,用于代码提示和类型检查,这个插件会根据你的代码中的类型注解,给出相应的提示和检查,比如你定义了一个函数,参数类型是int,那么当你传入一个字符串时,它会提示你传入的参数类型不正确。

变量类型注解语法为 变量名: 类型

# 变量的类型注解 name: str = "Alice" age: int = 30 height: float = 1.75 is_student: bool = False

函数类型注解为函数参数和返回值指定类型,语法为 def 函数名(参数: 类型) -> 返回类型。

def add(a: int, b: int) -> int: return a + b def greet(name: str) -> None: print(f"Hello, {name}")

类属性与方法的类型注解:为类的属性和方法添加类型信息。

# 定义一个矩形类 class Rectangle: width: float # 矩形宽度(浮点数),类属性的类型注解(不初始化值) height: float # 矩形高度(浮点数) def __init__(self, width: float, height: float): self.width = width self.height = height def area(self) -> float: # 计算面积(宽度 × 高度) return self.width * self.height
http://www.cnnetsun.cn/news/25259.html

相关文章:

  • 【上海交通大学主办 | 连续6年IEEE出版 | 连续5届快速检索-往届会后3个月EI, Scopus检索 | 设优秀评选】第六届IEEE信息科学与教育国际学术会议(ICISE-IE 2025)
  • 区块链核心知识点梳理(8)-钱包与账户体系
  • 如何快速开展中小学AI教育:完整的AI通识课程指南
  • LeetCode 6. Z 字形变换 | 详细题解(附 C++ 代码)
  • 22、Linux 系统基础管理入门指南
  • 2026年大模型应用开发学习路线:四阶段转型指南,抓住未来3年的职业发展机遇!转AI大模型开发学习顺序真的很重要!
  • 26、Linux文件系统管理全攻略
  • 27、Linux 系统文件管理与共享全攻略
  • 33、网络安全测试与Shell脚本编程入门
  • Reverse Engineer‘s Toolkit:一体化逆向工程解决方案
  • STC宏晶 STC8H8K64U-45I-LQFP64/烧录 LQFP64 单片机
  • 微信支付PHP SDK终极指南:快速集成APIv3和APIv2的完整解决方案
  • 将MacBook刘海变身为高效文件传输中心
  • 苹果App Store应用程序上架方式全面指南
  • Hikari-LLVM15终极指南:5分钟掌握代码混淆核心技术
  • 教你使用服务器搭建 Next.js 电商独立站方案 Your Next Store 完整教程
  • 1、掌握 AWS Lambda:构建无服务器应用的全面指南
  • 二.AI知识科普
  • 面向水工、市政与环保工程的渗流控制:有限元方法、程序修改与参数化分析
  • 9、AWS Lambda:事件驱动模型与外部服务集成实践
  • radix_tree_node(约 7.3 GB)
  • 互联网大厂Java求职面试深度指导——场景、问答及代码案例解析
  • OpCore Simplify:终极Hackintosh配置解决方案
  • PolarDB - PostgreSQL
  • POCO C++库:构建高性能网络应用的终极解决方案
  • WebPlotDigitizer 数据提取终极教程:从入门到精通
  • SpringBoot基于Java的网吧管理系统(毕业设计项目源码+文档)
  • 收藏必备!从提示工程到上下文工程:让AI效率提升40%的7大核心模式
  • ModernWMS开源仓库管理系统:从零部署到生产环境实战指南
  • arXiv LaTeX Cleaner终极指南:保护隐私、优化论文提交的完整方案