Python入门——__init__.py文件作用

init.py文件作用

__init__.py的三大核心功能

init.py三大核心功能
标记包python package
包被导入时,自动执行其中的初始化代码
通过__all__变量控制包的「公共接口」(封装性)

功能 1:标记包(最基础功能)

这是__init__.py的原始核心作用,即使文件内容为空,也能实现「标记目录为 Python 包」的效果。

如下所示,在pycharm中加入__init__.py后api变为python package标识

功能 2:包被导入时,自动执行其中的初始化代码

当通过import导入某个包时,Python 会自动执行该包下__init__.py文件中的所有代码,可用于完成包的初始化配置、定义全局变量、加载依赖等操作。

功能 3:通过__all__变量控制包的「公共接口」(封装性)

__init__.py中可以定义__all__列表,用于指定「当使用from 包名 import *时,能够被导入的成员(模块、类、函数、变量)」,从而隐藏包的内部细节,提升封装性,避免不必要的成员暴露。

示例(对应schemas/__init__.py):

python 复制代码
# 定义__all__,指定from schemas import * 时可导入的成员
__all__ = ["UserCreateRequest", "UserResponse", "GoodsCreateRequest", "GoodsResponse"]

# 提前导入子模块的成员,简化外部调用
from schemas.user import UserCreateRequest, UserResponse
from schemas.goods import GoodsCreateRequest, GoodsResponse

此时外部执行from schemas import *,只会导入__all__中指定的 4 个模型,而不会暴露schemas包内的其他内部细节,同时也简化了外部导入(无需写from schemas.user import UserCreateRequest)。

若不定义__all__from 包名 import *仅会导入该__init__.py中直接定义的成员,无法导入子模块的内容。

相关推荐
石榴树下的七彩鱼3 分钟前
医疗票据 OCR 识别 API 多场景落地指南:医保结算 + 商保理赔 + 医疗信息化(附 Python/Java 完整示例)
java·python·ocr·石榴智能·医疗票据ocr·医保结算·ocrapi
C137的本贾尼8 分钟前
Spring AI Alibaba 开箱:国产百炼大模型初体验
java·人工智能·spring
idingzhi27 分钟前
A股量化策略日报(2026年05月22日)
android·开发语言·python·kotlin
song50134 分钟前
多卡训练加速:HCCL 集合通信实战
分布式·python·flutter·ci/cd·分类
金銀銅鐵39 分钟前
[Java] 如何理解 class 文件中字段的 access flags?
java·后端
小短腿的代码世界1 小时前
Qt国际化深度解析:从源码到企业级多语言实践
java·数据库·qt
江上清风山间明月1 小时前
如何将python开发的window应用打包成exe
开发语言·python·exe·打包
知识分享小能手1 小时前
Flask入门学习教程,从入门到精通, Flask模板 — 完整知识点与案例代码 (2)
python·学习·flask
凌冰_1 小时前
IDEA 集成Claude Code
java·ide
SXJR1 小时前
Java中的Cross-Encoder模型解决方案
java·开发语言