python文件中导入另外一个模块这个模块

针对上文中的 calc_utils.py 模块,在另一个Python文件中导入并使用的核心原则是:确保模块文件与调用文件的路径关系正确,选择合适的导入语法。下面分「同目录」「不同目录」两种最常见场景,给出具体操作方法。

一、场景1:调用文件与模块文件在同一目录(最常用)

假设文件结构如下(两个文件在同一个文件夹下):

bash 复制代码
my_project/
  ├─ calc_utils.py  # 自定义模块
  └─ test.py        # 调用模块的文件

此时有3种导入方式,可按需选择:

方式1:导入整个模块,通过「模块名.成员」调用

python 复制代码
# test.py
# 导入整个calc_utils模块
import calc_utils

# 1. 访问模块中的变量
print("模块版本:", calc_utils.CALC_VERSION)

# 2. 调用模块中的函数
sum_result = calc_utils.add(10, 25)
print("10+25 =", sum_result)

# 3. 使用模块中的类
calc = calc_utils.AdvancedCalculator()
print("累加30:", calc.accumulate(30))

方式2:导入模块的指定成员(函数/类/变量),直接调用

适合仅需使用模块中部分功能的场景,代码更简洁:

python 复制代码
# test.py
# 导入模块中的指定函数、类、变量
from calc_utils import add, AdvancedCalculator, CALC_VERSION

# 直接使用,无需加模块名前缀
print("版本:", CALC_VERSION)
print("5+8 =", add(5, 8))

adv_calc = AdvancedCalculator()
print("累加100:", adv_calc.accumulate(100))

方式3:导入模块并指定别名(模块名过长时适用)

如果模块名较长(比如 calculator_utils.py),可给模块起别名,简化调用:

python 复制代码
# test.py
# 给模块指定别名cu
import calc_utils as cu

print("版本:", cu.CALC_VERSION)
print("12×5 =", cu.multiply(12, 5))

calc = cu.AdvancedCalculator()
print("累乘2:", calc.multiply_accumulate(2))

二、场景2:调用文件与模块文件在不同目录

假设文件结构如下(模块在子目录,调用文件在上级目录):

bash 复制代码
my_project/
  ├─ utils/          # 子目录
  │  └─ calc_utils.py # 模块文件
  └─ test.py         # 调用文件

此时需要先让Python找到模块的路径,有2种可靠方法:

方法1:通过「包导入」(推荐,工程化用法)

步骤1:在 utils 目录下新建 __init__.py 文件(空文件即可,用于标识该目录为Python包),结构变为:

markdown 复制代码
my_project/
  ├─ utils/
  │  ├─ __init__.py
  │  └─ calc_utils.py
  └─ test.py

步骤2:在 test.py 中导入(支持多种写法):

python 复制代码
# 写法1:导入包下的模块
import utils.calc_utils as cu

print(cu.add(3, 7))

# 写法2:直接导入模块中的成员
from utils.calc_utils import multiply, AdvancedCalculator

print(multiply(4, 9))

方法2:临时添加模块路径(快速测试用)

如果不想创建 __init__.py,可在调用文件中手动将模块所在目录加入Python搜索路径:

python 复制代码
# test.py
import sys
# 将utils目录的绝对路径添加到搜索路径(请替换为你自己的实际路径)
# 相对路径写法:sys.path.append("./utils")(推荐,无需改绝对路径)
sys.path.append("./utils")

# 之后即可像同目录一样导入
import calc_utils

print(calc_utils.add(8, 9))

三、运行与验证

无论哪种方式,运行 test.py 即可:

  1. 打开终端/命令行,进入 my_project 目录;
  2. 执行 python test.py
  3. 正常输出计算结果,说明导入成功。

四、常见问题与避坑

  1. 报错「ModuleNotFoundError: No module named 'calc_utils'」

    • 检查模块文件名是否拼写正确(比如少写 _、大小写错误);
    • 检查调用文件与模块文件的路径是否符合上述场景;
    • 若用「方法2」,确认添加的路径是模块所在目录的正确路径。
  2. 导入后修改模块代码,运行test.py不生效

    • Python会缓存导入的模块,修改后需重启 test.py

    • 若需动态重载,可添加以下代码:

      python 复制代码
      import calc_utils
      import importlib
      importlib.reload(calc_utils)  # 重新加载模块,读取最新代码
  3. 模块名与Python内置模块重名(比如命名为 math.py

    • 会覆盖内置模块,导致 import math 导入的是自定义模块而非系统模块;
    • 解决:修改自定义模块名(比如改为 my_math.py)。
相关推荐
CTA终结者9 小时前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链
马士兵教育10 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
KaMeidebaby10 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
Cloud_Shy61810 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
天佑木枫11 小时前
15天Python入门系列 · 序
开发语言·python
happylifetree11 小时前
Python017-第二章15.数据容器-dict常用操作
python
装不满的克莱因瓶11 小时前
了解 LangChain 中的 LLM 与 ChatModel 的差异
人工智能·python·ai·langchain·llm·agent·chatmodel
IT知识分享12 小时前
从零开发在线简繁转换工具:OpenCC 实战、避坑经验与方案选型
javascript·python
lunzi_082612 小时前
【学习笔记】《Python编程 从入门到实践》第8章:函数定义、参数传递与模块导入
笔记·python·学习
杨运交12 小时前
[030][Web模块]Spring Boot 验证与 OpenAPI 集成实战:从校验规则到文档生成
前端·spring boot·python