Python包結構與 `__init__.py` 詳解

1. 什么是 __init__.py

__init__.py 是Python包的標識文件,它告訴Python解釋器這個目錄應該被視為一個包(Package)。這個文件可以為空,也可以包含初始化代碼。

1.1 基本作用

  1. 包的標識

    • 將普通目錄轉換為Python包
    • 允許包的導入
    • 定義包的命名空間
  2. 初始化包

    • 在導入包時執行初始化代碼
    • 設置包級別的變量
    • 導入必要的依賴

2. 目錄結構示例

my_package/__init__.pymodule1.pymodule2.pysubpackage/__init__.pymodule3.pymodule4.py

3. __init__.py 的常見用法

3.1 空的 __init__.py

最簡單的用法是創建一個空文件:

# __init__.py
# 這個文件可以為空

3.2 導入和重新導出模塊

# my_package/__init__.py# 從子模塊導入并重新導出
from .module1 import function1, function2
from .module2 import Class1, Class2# 現在可以直接從包中導入這些內容
# from my_package import function1, Class1

3.3 初始化代碼

# my_package/__init__.py# 包級別的初始化
print("Initializing my_package...")# 設置包級別的變量
VERSION = "1.0.0"
AUTHOR = "Your Name"# 初始化包的配置
def initialize():print("Setting up my_package...")# 初始化代碼# 導入時自動執行
initialize()

3.4 控制導入的內容

# my_package/__init__.py# 定義可以被導入的內容
__all__ = ['function1', 'Class1', 'VERSION']from .module1 import function1
from .module2 import Class1
VERSION = "1.0.0"

4. 實際應用示例

4.1 簡單的工具包

# utils/__init__.pyfrom .string_utils import capitalize_words
from .math_utils import calculate_average
from .file_utils import read_json__all__ = ['capitalize_words', 'calculate_average', 'read_json']
VERSION = '0.1.0'def get_version():return VERSION

4.2 數據庫連接包

# database/__init__.pyimport os
from .connection import DatabaseConnection
from .queries import QueryBuilder# 設置默認配置
DEFAULT_CONFIG = {'host': 'localhost','port': 5432,'database': 'mydb'
}# 創建全局連接實例
def create_connection(config=None):if config is None:config = DEFAULT_CONFIGreturn DatabaseConnection(**config)# 導出的內容
__all__ = ['DatabaseConnection', 'QueryBuilder', 'create_connection']

4.3 Web應用包

# webapp/__init__.pyfrom flask import Flask
from .config import Config
from .routes import register_routes
from .database import init_dbapp = Flask(__name__)def create_app(config_class=Config):# 配置應用app.config.from_object(config_class)# 初始化組件init_db(app)register_routes(app)return app

5. 最佳實踐

5.1 組織代碼

  1. 清晰的層次結構

    # 在頂層__init__.py中組織導入
    from .core import Core
    from .utils import Utils
    from .config import Config
    
  2. 版本控制

    # __init__.py
    __version__ = '1.0.0'
    __author__ = 'Your Name'
    __license__ = 'MIT'
    

5.2 避免循環導入

# 使用延遲導入避免循環依賴
def get_helper():from .helper import Helperreturn Helper()

5.3 文檔化

"""
My Package
~~~~~~~~~~這個包提供了一些有用的工具函數。基本用法:>>> from my_package import function1>>> function1()
"""from .core import *

6. 常見問題和解決方案

6.1 循環導入

問題:

# a.py
from .b import B
class A:pass# b.py
from .a import A
class B:pass

解決方案:

# a.py
class A:def get_b(self):from .b import Breturn B()# b.py
class B:def get_a(self):from .a import Areturn A()

6.2 導入路徑問題

# 使用相對導入
from . import module1
from .. import sibling_package
from ..sibling_package import some_function

7. 性能考慮

  1. 延遲加載

    # __init__.py
    def get_large_module():# 只在需要時才導入大型模塊from .large_module import LargeClassreturn LargeClass()
    
  2. 條件導入

    # __init__.py
    try:from .fast_implementation import function
    except ImportError:from .slow_implementation import function
    

8. 總結

__init__.py 文件是Python包系統的重要組成部分,它可以:

  • 標識Python包
  • 初始化包的狀態
  • 提供包級別的變量和函數
  • 控制導入的內容
  • 簡化包的使用方式

正確使用 __init__.py 可以使包的結構更清晰、使用更方便、維護更容易。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/72805.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/72805.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/72805.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Web前端開發——HTML基礎下

HTML語法 一表格1.基本格式2.美化表格合并居中屬性 二表單1.input2.select3.textarea4.button5.date6.color7.checkbox8.radio9.range10.number 一表格 1.基本格式 HTML表格由<table>標簽定義 其中行由<tr>標簽定義&#xff0c;單元格由<td>定義。我們先來…

小程序事件系統 —— 33 事件傳參 - data-*自定義數據

事件傳參&#xff1a;在觸發事件時&#xff0c;將一些數據作為參數傳遞給事件處理函數的過程&#xff0c;就是事件傳參&#xff1b; 在微信小程序中&#xff0c;我們經常會在組件上添加一些自定義數據&#xff0c;然后在事件處理函數中獲取這些自定義數據&#xff0c;從而完成…

安卓設備root檢測與隱藏手段

安卓設備root檢測與隱藏手段 引言 安卓設備的root權限為用戶提供了深度的系統控制能力&#xff0c;但也可能帶來安全風險。因此&#xff0c;許多應用&#xff08;如銀行軟件、游戲和流媒體平臺&#xff09;會主動檢測設備是否被root&#xff0c;并限制其功能。這種對抗催生了ro…

如何在Ubuntu上直接編譯Apache Doris

以下是在 Ubuntu 22.04 上直接編譯 Apache Doris 的完整流程&#xff0c;綜合多個版本和環境的最佳實踐&#xff1a; 注意&#xff1a;Ubuntu的數據盤VMware默認是20G&#xff0c;編譯不夠用&#xff0c;給到50G以上吧 一、環境準備 1. 安裝系統依賴 # 基礎構建工具鏈 apt i…

vuejs相關鏈接和格式化插件推薦

vue官網&#xff1a; https://cn.vuejs.org/ 配合路由設置&#xff1a; https://router.vuejs.org/zh/guide/ element plus (vue3) | element UI (vue2)&#xff1a; https://element-plus.org/zh-CN/#/zh-CN 構建工具vite&#xff1a; https://cn.vitejs.dev/ 右鍵選擇…

IDEA中Git版本回退終極指南:Reset與Revert雙方案詳解

目錄 前言一、版本回退前置知識二、Reset方案&#xff1a;整體改寫歷史1、IDEA圖形化操作&#xff08;推薦&#xff09;1.1、查看提交歷史1.2、選擇目標版本1.3、選擇回退模式1.3.1、Soft&#xff08;推薦&#xff09;1.3.2、Mixed1.3.3、Hard&#xff08;慎用&#xff09;1.3.…

PHP并發請求優化:使用`curl_multi_select()`實現高效的多請求處理

PHP并發請求優化&#xff1a;使用curl_multi_select()實現高效的多請求處理 背景 最近在項目中遇到一個需求&#xff0c;需要從多個 1 級網站&#xff08;超過 200 個&#xff09;獲取數據&#xff0c;并且是通過 POST 請求瞬間發送到這些網站上。開始時我直接使用了 curl_ex…

【leetcode hot 100 206】反轉鏈表

解法一&#xff1a;&#xff08;頭插法&#xff09;在遍歷鏈表時&#xff0c;將當前節點的 next 指針改為指向前一個節點。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val)…

【QT】-易錯點筆記-2025-2-7

1,QList<phy_simulator*> pList;為空不能append()追加,要先new,再用 QList<phy_simulator> pList為空時,確實不能調用 append() 方法。原因很簡單,QList 是一個類對象,在 C++ 中,指針本身并不代表它指向的對象。因此,當你有一個指向 QList<phy_simulato…

AI-Deepseek + PPT

01--Deepseek提問 首先去Deepseek問一個問題&#xff1a; Deepseek的回答&#xff1a; 在汽車CAN總線通信中&#xff0c;DBC文件里的信號處理&#xff08;如初始值、系數、偏移&#xff09;主要是為了 將原始二進制數據轉換為實際物理值&#xff0c;確保不同電子控制單元&…

實驗一:在Windows 10/11下配置和管理TCP/IP

目錄 1.【實訓目標】 2.【實訓環境】 3.【實訓內容】 4.【實訓步驟】 1.【實訓目標】 1.了解網絡基本配置中包含的協議、服務、客戶端。 2.了解Windows支持的網絡協議及參數設置方法。 3.掌握TCP/IP協議的配置。 2.【實訓環境】 硬件環境&#xff1a;每人一臺計算機&a…

Java直通車系列14【Spring MVC】(深入學習 Controller 編寫)

目錄 基本概念 編寫 Controller 的步驟和要點 1. 定義 Controller 類 2. 映射請求 3. 處理請求參數 4. 調用業務邏輯 5. 返回響應 場景示例 1. 簡單的 Hello World 示例 2. 處理路徑變量和請求參數 3. 處理表單提交 4. 處理 JSON 數據 5. 異常處理 基本概念 Cont…

EA - 開源工程的編譯

文章目錄 EA - 開源工程的編譯概述筆記環境備注x86版本EABase_x86EAAssert_x86EAThread_x86修改 eathread_atomic_standalone_msvc.h原始修改后 EAStdC_x86EASTL_x86EAMain_x86EATest_x86備注備注END EA - 開源工程的編譯 概述 EA開源了‘命令與征服’的游戲源碼 嘗試編譯. 首…

一招解決Pytorch GPU版本安裝慢的問題

Pytorch是一個流行的深度學習框架&#xff0c;廣泛應用于計算機視覺、自然語言處理等領域。安裝Pytorch GPU版本可以充分利用GPU的并行計算能力&#xff0c;加速模型的訓練和推理過程。接下來&#xff0c;我們將詳細介紹如何在Windows操作系統上安裝Pytorch GPU版本。 查看是否…

為解決局域網IP、DNS切換的Windows BAT腳本

一、背景 為解決公司普通人員需要切換IP、DNS的情況&#xff0c;于是搞了個windows下的bat腳本&#xff0c;可以對有線網絡、無線網絡進行切換設置。 腳本內容 echo off title 多網絡接口IP切換工具:menu cls echo echo 請選擇要配置的網絡接口: echo echo 1. 有線網絡&am…

uni_app實現下拉刷新

1. 在頁面配置中啟用下拉刷新 首先&#xff0c;你需要在頁面的 pages.json 文件中啟用下拉刷新功能。 {"pages": [{"path": "pages/index/index","style": {"navigationBarTitleText": "首頁","enablePull…

OpenCV計算攝影學(14)實現對比度保留去色(Contrast Preserving Decolorization)的函數decolor()

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 將彩色圖像轉換為灰度圖像。它是數字印刷、風格化的黑白照片渲染&#xff0c;以及許多單通道圖像處理應用中的基本工具。 cv::decolor 是 OpenCV…

Qt常用控件之 縱向列表QListWidget

縱向列表QListWidget QListWidget 是一個縱向列表控件。 QListWidget屬性 屬性說明currentRow當前被選中的是第幾行。count一共有多少行。sortingEnabled是否允許排序。isWrapping是否允許換行。itemAlignment元素的對齊方式。selectRectVisible被選中的元素矩形是否可見。s…

關于 QPalette設置按鈕背景未顯示出來 的解決方法

若該文為原創文章&#xff0c;轉載請注明原文出處 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/146047054 長沙紅胖子Qt&#xff08;長沙創微智科&#xff09;博文大全&#xff1a;開發技術集合&#xff08;包含Qt實用技術、樹莓派、三維、OpenCV…

PostgreSQL 安裝與使用

下載地址: EDB: Open-Source, Enterprise Postgres Database Management 安裝圖形化安裝界面安裝。安裝完后將bin目錄配置到系統環境變量 執行psql -h localhost -p 5432 -U postgres 密碼在安裝過程中設置的 ? 0、修改密碼 ALTER USER sonar WITH PASSWORD 123456; 1、新…