主頁 > 後端開發 > Python開發中自動化構建專案結構樣式

Python開發中自動化構建專案結構樣式

2023-06-28 07:29:34 後端開發

摘要:在專案開發程序中,一個良好的專案結構對于團隊的協作和代碼的可維護性起著重要作用,通過使用自動生成專案結構文字樣式的工具,不僅節省了手動撰寫專案結構的麻煩,還確保了結構的一致性和準確性,

本文分享自華為云社區《【Python】自動化構建專案結構樣式》,作者: frica01,

引言

在使用 Python 或者其它編程語言的專案時候,撰寫 README.md 往往是不可或缺的;

而在 README.md 中,關于專案結構的樣式展示,這個是可選的,不展示也無傷大雅,但有展示的話,有以下優點:

  • 提供清晰的專案導航:包含專案結構的文字樣式可以讓讀者快速了解專案的組織方式和檔案結構,這對于新加入的開發人員或用戶來說尤為重要,他們可以迅速找到所需的檔案和模塊,并理解它們之間的關系,

但是怎么去撰寫這個專案結構的樣式,卻很令人頭疼,

手動撰寫和更新這些結構可能會變得很繁瑣和容易出錯,因此,有自動生成專案結構文字樣式的工具或腳本可以極大地簡化這個程序,提高效率并減少錯誤,

所以本文就是來解決這一痛點!!!

展示

應該沒有人不心動吧!!!

下面使用筆者的一個 PySide6/PyQT 開發的一個專案的專案結構來作展示,

一個Python寫的游戲輔助小工具,適用于 咸魚之王后臺掛機、滑鼠連擊等,

看以下動圖展示:

再來看下面的截圖

知識點

安裝依賴

  • 免安裝,Python 內置

匯入模塊

import os

主要使用到了 os 模塊的幾個方法,如下(它們在處理檔案和目錄時非常有用,可以幫助你進行路徑操作和檔案系統操作):

使用這些函式可以更方便地處理檔案路徑和目錄操作,

  • os.path.join 用于安全地連接路徑
  • os.path.isdir 用于檢查路徑是否為目錄
  • os.path.basename 用于提取路徑的最后一部分
  • os.getcwd 用于獲取當前作業目錄,

為什么是自動化構建專案結構樣式

基于以下的好處和作用,讀者朋友又有什么理由會拒絕這份寶藏代碼呢!!!

好處

通過使用自動生成專案結構文字樣式的工具,可以輕松地生成專案的目錄結構,并將其插入到 README.md 檔案中,好處如下:

  1. 節省時間和精力:手動撰寫和更新專案結構的文字樣式可能會很耗時且容易出錯,自動生成工具可以快速而準確地生成專案結構,節省了手動處理的時間和精力,
  2. 保持一致性:自動生成工具可以確保專案結構的文字樣式始終保持一致,無論專案如何演變和更新,都可以輕松地更新專案結構,以反映最新的變化,而無需手動更改 README.md 檔案,
  3. 易于維護:通過自動生成工具生成的專案結構文字樣式,可以更容易地進行維護和更新,當專案的檔案或目錄發生變化時,只需重新運行自動生成工具,即可更新 README.md 中的專案結構,而無需手動修改和調整,
  4. 提供清晰的專案導航:包含專案結構的文字樣式可以讓讀者快速了解專案的組織方式和檔案結構,這對于新加入的開發人員或用戶來說尤為重要,他們可以迅速找到所需的檔案和模塊,并理解它們之間的關系,

綜上所述,通過自動生成專案結構文字樣式,可以簡化撰寫 README.md 的程序,提高檔案的一致性和可維護性,并為專案的使用者提供清晰的導航和理解,這樣的工具可以幫助開發者更專注于專案的開發和功能實作,而不必過多關注檔案的細節和更新,

作用

自動化構建專案結構樣式在 Python 專案中具有以下作用:

  1. 專案檔案:生成專案結構的文字樣式可以作為專案檔案的一部分,提供專案的概覽和檔案組織結構的資訊,它可以幫助新加入的開發人員快速了解專案的組織和檔案分布,
  2. 代碼說明:專案結構文字樣式可以與代碼注釋一起使用,對各個模塊、包和檔案進行說明,這有助于其他開發人員更好地理解代碼的組織方式,快速找到所需的檔案和模塊,
  3. 專案展示:在專案演示或展示的程序中,使用專案結構文字樣式可以直觀地展示專案的檔案和檔案夾結構,這樣可以幫助觀眾更好地理解專案的組織方式,并對專案的規模和復雜度有一個直觀的認識,

總之,生成專案結構的文字樣式可以在專案檔案、代碼說明和專案展示中提供清晰的專案結構資訊,幫助開發人員更好地理解和使用專案,

代碼

遞回地遍歷指定目錄下的檔案和檔案夾,并按照特定的格式輸出它們的結構,

# -*- coding: utf-8 -*-
# @Author : Frica01
# @Time   : 2023-06-22 0:00
# @Name   : project_structure_generator.py
import os
# 需要排除的檔案夾串列
exclude_folders = ['.git', '.idea', '.vscode', 'venv', '__pycache__', 'project_structure_generator.py']
def generate_project_structure(directory, indent='', is_last=False, is_root=False, output_file=None):
 """
 生成專案結構的文字樣式
 Args:
        directory (str): 目錄路徑
        indent (str): 縮進字串
 is_last (bool): 是否是最后一個元素
 is_root (bool): 是否是根目錄
 output_file (file): 輸出檔案物件
    Returns:
        None
    """
 # 獲取目錄中的檔案和檔案夾串列,并按照一定的規則排序
    items = sorted(os.listdir(directory),
                   key=lambda x: (not os.path.isdir(os.path.join(directory, x)), x != '__init__.py', x))
 num_items = len(items)
 if is_root:
 # 根目錄名稱
 output_file.write(f"{os.path.basename(os.getcwd())}/\n")
 for i, item in enumerate(items):
 if item in exclude_folders:
 continue
 item_path = os.path.join(directory, item)
 is_item_last = i == num_items - 1
 if os.path.isdir(item_path):
 # 如果是目錄,則添加目錄標記并遞回生成目錄結構
            marker = '└── ' if is_item_last else '├── '
 output_file.write(f"{indent}{marker}{item}/\n")
 new_indent = indent + ('    ' if is_last else '')
 generate_project_structure(item_path, new_indent, is_item_last, output_file=output_file)
 else:
 # 如果是檔案,則添加檔案標記
            marker = '└── ' if is_item_last else '├── '
 output_file.write(f"{indent}{marker}{item}\n")
if __name__ == '__main__':
 # 打開要寫入的檔案
 with open('project_structure.txt', 'w') as file:
 # 生成專案結構并寫入檔案
 generate_project_structure('.', is_root=True, output_file=file)
 print("目錄結構已寫入檔案 project_structure.txt")

結語

在專案開發程序中,一個良好的專案結構對于團隊的協作和代碼的可維護性起著重要作用,通過使用自動生成專案結構文字樣式的工具,如我們在代碼中實現的 project_structure_generator.py,我們可以輕松地生成專案結構的可視化表示,并將其整理為一個文本檔案,這個工具不僅節省了手動撰寫專案結構的麻煩,還確保了結構的一致性和準確性,

號外

7 月 7 日,華為開發者大會 2023 (Cloud) 將拉開帷幕,并將在國內 30 多個城市、海外 10 多個國家開設分會場,誠邀您參加這場不容錯過的年度開發者盛會,讓我們一起開啟探索之旅!

我們將攜手開發者、客戶、合作伙伴,為您呈現華為云系列產品服務與豐富的創新實踐,并與您探討 AI、大資料、資料庫、PaaS、aPaaS、媒體服務、云原生、安全、物聯網、區塊鏈、開源等技識訓題,展開全面深入的交流,

大會將匯聚全球科學家、行業領袖、技術專家、社區大咖,開設 200 多場開發者專題活動,為全球開發者提供面對面交流與合作的機會,共同探討技術創新和業務發展,

大會官網:https://developer.huaweicloud.com/HDC.Cloud2023.html

參會購票:https://www.vmall.com/product/10086352254099.html?cid= 211761

點擊參與開發者社區活動,觀賞技術大咖秀、玩轉技術夢工廠,有機會贏取4000元開發者禮包!

歡迎關注 “華為云開發者聯盟” 公眾號,獲取大會議程、精彩活動和前沿干貨,

 

點擊關注,第一時間了解華為云新鮮技術~

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/556099.html

標籤:Python

上一篇:執行緒池

下一篇:返回列表

標籤雲
其他(161701) Python(38255) JavaScript(25515) Java(18266) C(15238) 區塊鏈(8273) C#(7972) AI(7469) 爪哇(7425) MySQL(7270) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5875) 数组(5741) R(5409) Linux(5347) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4607) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2437) ASP.NET(2404) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1985) HtmlCss(1974) 功能(1967) Web開發(1951) C++(1942) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1881) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • Python開發中自動化構建專案結構樣式

    摘要:在專案開發程序中,一個良好的專案結構對于團隊的協作和代碼的可維護性起著重要作用。通過使用自動生成專案結構文字樣式的工具。不僅節省了手動撰寫專案結構的麻煩,還確保了結構的一致性和準確性。 本文分享自華為云社區《【Python】自動化構建專案結構樣式》,作者: frica01。 引言 在使用 Py ......

    uj5u.com 2023-06-28 07:29:34 more
  • 執行緒池

    # 執行緒池 ## 簡介 執行緒池是一種基于池化思想的執行緒管理工具。 ## 優點 - 降低資源消耗 - 提高回應速度 - 提高執行緒的可管理性 - 提供可擴展性 ## 使用場景 - 連接池 - 執行緒隔離 - 開發中需要創建5個以上的執行緒就可以考慮使用執行緒池 ## 執行緒池核心引數 | 引數名 | 型別 | ......

    uj5u.com 2023-06-28 07:22:09 more
  • Spring Cloud Gateway編碼實作任意地址跳轉

    面對同樣的客戶端請求,SpringCloud Gateway可以轉發給不同的服務去處理,掌握這個技能,讓請求從微服務入口處被掌控,被調度 ......

    uj5u.com 2023-06-27 09:31:30 more
  • Spring Cloud Gateway編碼實作任意地址跳轉

    面對同樣的客戶端請求,SpringCloud Gateway可以轉發給不同的服務去處理,掌握這個技能,讓請求從微服務入口處被掌控,被調度 ......

    uj5u.com 2023-06-27 09:24:59 more
  • 我將青春奉獻給了我喜歡的事情,卻讓我無法解決溫

    時間過的很快,3 年的疫情就這么過去了,留下的卻是緊張的社會氛圍。 目前已經在計算機行業 7 年了,記得那是 2015 年,當時我也才 15 歲,正在讀初二。那會特別喜歡別人的網站,比如卡盟,還有代掛等等別人的那些網站,然后我入坑了。我那會百度怎么做一個網站,然后搜出來需要學習 html,那時候,我 ......

    uj5u.com 2023-06-27 07:55:51 more
  • Java 網路編程 —— 安全網路通信

    ## SSL 簡介 SSL(Secure Socket Layer,安全套接字層)是一種保證網路上的兩個節點進行安全通信的協議。IETF(Interet Engineering Task Force)國際組織對 SSL 作了標準化,制定了 RFC2246 規范,并將其稱為傳輸層安全(Transpor ......

    uj5u.com 2023-06-27 07:55:47 more
  • 【技識訓累】Spring Boot中的基礎知識【一】

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-06-27 07:55:20 more
  • [滲透測驗]—2.3 密碼破解技術

    在本節中,我們將介紹一些常見的密碼破解技術。我們將涵蓋以下技術: 1. 字典攻擊 2. 暴力破解 3. 彩虹表 4. 社會工程攻擊 5. 密碼重置攻擊 6. 密碼保護存盤攻擊 7. 離線密碼破解 ### 1. 字典攻擊 字典攻擊是一種破解密碼的方法,它使用預先編譯的單詞串列(字典)作為密碼猜測的來源 ......

    uj5u.com 2023-06-27 07:54:59 more
  • Kubernetes 系列:Kubernetes 的安裝(三)

    ### 序 前面介紹了k8s組件和物件的一些基本概念,了解了k8s具體是做什么的以及架構,那么接下來我們開始介紹怎么去安裝k8s,這里我們以windows為例,其他平臺可以參考Kubernetes官方檔案,其實安裝方式都是類似的。 ### 先決條件 要在系統中安裝 Kubernetes,以下是一些需 ......

    uj5u.com 2023-06-27 07:54:43 more
  • C++面試八股文:std::deque用過嗎?

    某日二師兄參加XXX科技公司的C++工程師開發崗位第26面: > 面試官:`deque`用過嗎? > > 二師兄:說實話,很少用,基本沒用過。 > > 面試官:為什么? > > 二師兄:因為使用它的場景很少,大部分需要性能、且需要自動擴容的時候使用`vector`,需要隨機插入和洗掉的時候可以使用` ......

    uj5u.com 2023-06-27 07:54:29 more