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

day30 导包

浙大疏锦行
作业:
项目目录如下,必须要__init__.py 表示util是一个包

my_project/                 <-- 项目根目录
|
├── main_script.py          <-- 主运行脚本
|
└── utils/                  <-- 工具包|├── __init__.py         <-- (空文件,但必须存在,表示这是一个包)|└── calculator.py       <-- 存放计算函数

编写模块代码

# utils/calculator.py
"""这是一个包含计算函数的模块。"""
import mathdef circle_area(radius):"""计算圆面积"""if radius < 0:return 0return math.pi * radius ** 2def rectangle_area(length, width):"""计算矩形面积"""if length < 0 or width < 0:return 0return length * width

导包

# main_script.py
import sys
import os# --- 动态修改 sys.path (这是最稳健的方式,我们保留它) ---
# 这一部分确保无论你在哪里运行脚本,项目根目录总能被找到
try:project_root = os.path.dirname(os.path.abspath(__file__))if project_root not in sys.path:sys.path.insert(0, project_root)
except NameError:# 在交互式环境(如Jupyter)中,__file__ 未定义,使用 os.getcwd()project_root = os.getcwd()if project_root not in sys.path:sys.path.insert(0, project_root)# --- 导入并进行调试 ---
try:from utils import calculator# 【新增的调试步骤】: 打印出 calculator 模块中所有可用的属性和方法# 这可以帮助我们确认 'circle_area' 是否真的被加载了print("--- 正在检查 'calculator' 模块内容 ---")print(dir(calculator))print("------------------------------------")# --- 调用函数 ---print("\n--- 正在调用函数 ---")radius = 10# 错误通常发生在这里area = calculator.circle_area(radius)print(f"✅ 计算成功!半径为 {radius} 的圆,面积是: {area:.2f}")except ImportError as e:print(f"❌ 导入失败: {e}。请检查项目结构和文件名是否正确。")
except AttributeError as e:print(f"❌ 属性错误: {e}")print("\n👉【解决方案】: 这个错误通常意味着目标函数没有在模块中被正确定义或加载。")print("   1. 请务必确认 `utils/calculator.py` 文件内容正确无误且已保存。")print("   2. 请务必删除 `utils` 文件夹下的 `__pycache__` 文件夹,然后重新运行。")
http://www.lqws.cn/news/454087.html

相关文章:

  • html和css实现文本打断换行、自动换行
  • postgresql DDL脚本
  • 电影感户外柔和光线人像街拍摄影后期Lr调色教程,手机滤镜PS+Lightroom预设下载!
  • 高防IP怎么选
  • 开源CMS vs 闭源CMS:二次开发究竟有何不同?
  • 工具:Autosar:DBC转ARXML
  • PLuTo 编译器示例17-20
  • 24. 开发者常用工具:抓包,弱网模拟,元素检查
  • TDengine 与开源可视化编程工具 Node-RED 集成
  • 基于微信小程序的美食点餐订餐系统
  • tkinter Text 组件学习指南
  • Python函数:全面教程
  • 【秒杀系统设计】
  • Logback 在java中的使用
  • VS2022 C#【自动化文件上传】AutoFileUpload 新需求 V13
  • 从“数据困境”到“数据生态”:DaaS重塑三甲医院医疗数据治理
  • android 渲染流水线中的两个重要阶段:swapBuffers 和 DrawFrames
  • Unity技能编辑器深度构建指南:打造专业级战斗系统
  • 项目开发中途遇到困难的解决方案
  • 跑步还是快速走,瘦身分享
  • 【unitrix】 3.4 类型级逻辑运算(bit.rs)
  • 广州AR公司诚推广州华锐互动​
  • 常用 Docker 命令整理
  • 设置vscode使用eslint
  • SynchronizedMap 和 ConcurrentHashMap 的区别
  • EfficientVLA:面向视觉-语言-动作模型无训练的加速与压缩
  • Xilinx XC7A12T‑1CPG238I Artix‑7 FPGA
  • 08-Python文件处理
  • MySQL EXPLAIN中的key_len终极指南:精准掌握索引使用情况
  • 【unitrix】 3.5 类型级别的比较系统(cmp.rs)