在 Python 中导入自己编写的 .py 文件,遵循以下基本原则:

1. 确保文件结构与导入路径

  • 将您编写的 Python 模块(.py 文件)放在合适的目录结构中。
  • 确保待导入的模块与当前执行文件(主程序)位于同一目录,或者位于已知的目录(如在 sys.path 中的目录)内,或者它们之间的关系可以通过相对导入来表达。

2. 使用标准导入语句

  • 使用 import 语句来导入模块。如果模块名与文件名相同(不包括扩展名),可以直接使用模块名。例如,如果您有一个名为 my_module.py 的文件,导入时使用:


python

import my_module
  • 如果模块位于某个子目录中,需要按照目录结构进行导入。例如,有一个目录结构如下:
project/
       main.py
       modules/
         my_module.py

在 `main.py` 中导入 `my_module.py`:

python

import modules.my_module
  • 如果需要导入模块中的某个特定对象(如函数、类或变量),可以使用 from ... import ... 语句。例如,假设 my_module.py 中有一个名为 my_function 的函数:
  • python
from modules.my_module import my_function

3. 处理相对导入

  • 如果模块间存在嵌套关系,可以使用相对导入。例如:
project/
       package/
         __init__.py
         subpackage/
           __init__.py
           module_a.py
         module_b.py

在 `module_b.py` 中导入 `subpackage/module_a.py` 中的 `foo` 函数:

from .subpackage.module_a import foo

 

  • 注意,使用相对导入时,当前模块必须是一个包的一部分(即在其目录下有 __init__.py 文件)。同时,相对导入通常在同一个包内或包的子包间使用。

4. 配置 Python 寻找模块的路径

  • 如果模块不在标准路径(如 sys.path)中,可以通过以下方式之一解决:
  • 将模块移至标准路径下:如将模块放入 Python 安装目录的 site-packages 目录,或用户的 site-packages 目录(如 ~/.local/lib/pythonX.Y/site-packages)。
  • 修改 PYTHONPATH 环境变量:在启动 Python 解释器之前,设置 PYTHONPATH 环境变量,包含待导入模块所在的目录。
  • 在代码中动态添加路径:在主程序开始处使用 sys.path.append 或 sys.path.insert 添加待导入模块的目录。

5. 避免命名冲突

  • 选择具有描述性和独特性的模块名,避免与标准库或其他第三方库中的模块名冲突。

遵循以上原则,您应该能够顺利地在 Python 程序中导入自己编写的 .py 文件。如果遇到问题,检查模块的文件路径、导入语句的正确性以及 Python 寻找模块的路径设置。