Keil一鍵添加.c文件和頭文件路徑腳本--可遍歷添加整個文件夾

来源:https://www.cnblogs.com/xiaoliu1012/p/18238997
-Advertisement-
Play Games

最近想移植個LVGL玩玩,發現文件實在是太多了,加的手疼都沒搞完,實在不想搞了就去找腳本和工具,基本沒找到一個。。。。。。 主要是自己也懶得去研究寫腳本,偶然搜到了一個博主寫的腳本,原博客地址:https://blog.csdn.net/riyue2044/article/details/13942 ...


最近想移植個LVGL玩玩,發現文件實在是太多了,加的手疼都沒搞完,實在不想搞了就去找腳本和工具,基本沒找到一個。。。。。。

主要是自己也懶得去研究寫腳本,偶然搜到了一個博主寫的腳本,原博客地址:https://blog.csdn.net/riyue2044/article/details/139424599

但是有以下問題:

1.這個腳本的.h文件也加在了分組下麵,這樣一般是不對的,應該加在Target的C/C++的Include path裡面

2.腳本沒有重覆添加檢測,導致如果多次添加,會損壞工程文件

3.輸入是命令行式的,使用者可能會忘了參數具體設置

 

之前沒接觸過XML,python也不熟,所以研究了一下,做以下修改

1.把之前的命令行式的輸入改為先運行再輸入,會提示具體的參數設置,有預設參數,是以我的工程包來寫的

2.把.h文件路徑直接加在了Target的C/C++的Include path裡面

3.加入文件路徑檢測,重覆添加不會導致文件損壞

4.加入更多提示

5.加入三種模式    0:.c文件和.h路徑會一起添加 1:只加.c文件 2:只加.h路徑

 

使用方法:需要安裝python,或者用python打包成exe文件也可,命令參考:pyinstaller -F -i .\icon.ico .\keil_add_file.py,放個百度雲的鏈接,裡面有我打包好的,不過註意殺毒軟體估計會報毒,請添加信任

鏈接:https://pan.baidu.com/s/1zC7kVboAtQwHZ2Zy5RFmIw?pwd=arzd
提取碼:arzd

腳本需放在keil工程目錄,需要添加的目錄則以相對路徑填充,比如"../../../external/lvgl",需要註意的是分組需要提前在keil裡面創建好,這個懶得改了,有需要的朋友可以自行修改

腳本內容如下:

  1 import os
  2 import glob
  3 import xml.etree.ElementTree as ET
  4 import argparse
  5 
  6 from multiprocessing import Event
  7 
  8 def indent(elem, level=0):
  9     """ Helper function to indent the XML for pretty printing. """
 10     i = "\n" + level * "    "
 11     if len(elem):
 12         if not elem.text or not elem.text.strip():
 13             elem.text = i + "    "
 14         if not elem.tail or not elem.tail.strip():
 15             elem.tail = i
 16         for elem in elem:
 17             indent(elem, level + 1)
 18         if not elem.tail or not elem.tail.strip():
 19             elem.tail = i
 20     else:
 21         if level and (not elem.tail or not elem.tail.strip()):
 22             elem.tail = i
 23         if not elem.tail:
 24             elem.tail = "\n"
 25 
 26 def add_files_to_group(uvprojx_file_path, mode,folder_path, group_name_target):
 27     # 改變文件擴展名從 .uvprojx 到 .xml
 28     base, ext = os.path.splitext(uvprojx_file_path)
 29     if ext != '.uvprojx':
 30         print("工程文件擴展名不正確")
 31         return
 32     
 33     xml_path = base + '.xml'
 34     os.rename(uvprojx_file_path, xml_path)
 35 
 36     try:
 37         #解析XML文件
 38         tree = ET.parse(xml_path)
 39         #獲取根節點
 40         root = tree.getroot()
 41 
 42         if mode == 0 or mode == 1:
 43             # 找到指定GroupName的Group節點
 44             target_group = None
 45             for group in root.findall('.//Group'):
 46                 group_name = group.find('GroupName')
 47                 if group_name is not None and group_name.text == group_name_target:
 48                     target_group = group
 49                     break
 50 
 51             if target_group is None:
 52                 print(f"未發現 '{group_name_target}' 分組,請先創建分組後再嘗試")
 53                 # 將文件擴展名改回 .uvprojx
 54                 os.rename(xml_path, uvprojx_file_path)
 55                 return
 56 
 57             # 找到目標 Group 節點下的 Files 節點,如果不存在則創建一個
 58             files_node = target_group.find('Files')
 59             if files_node is None:
 60                 files_node = ET.SubElement(target_group, 'Files')
 61                                 
 62         #尋找頭文件分組
 63         if mode == 0 or mode == 2:
 64             print("尋找頭文件分組......")
 65             target_header = None
 66             heard_inc = None
 67             target_header = root.find('.//Cads')
 68             if target_header == None:
 69                 print("未發現頭文件分組Cads")
 70                 return
 71             else:
 72                 heard_inc = target_header.find('VariousControls')
 73                 if heard_inc == None:
 74                     print("未發現頭文件分組VariousControls")
 75                     return
 76                 else:
 77                     heard_inc = heard_inc.find('IncludePath')
 78                     if heard_inc == None:
 79                         print("未發現頭文件分組IncludePath")
 80                         return
 81                     else:
 82                         print("找到頭文件分組")
 83                        
 84         
 85         
 86         #下麵沒有節點
 87         if mode == 0 or mode == 1:
 88             creat_dot = 0 #是否需要創建節點標誌,如果有重覆則跳過 
 89             init_creat = 0
 90             file_init = files_node.find('File')
 91             if file_init == None:
 92                 creat_dot = 1
 93                 init_creat = 1
 94                 print("初始節點為空需要創建節點")
 95   
 96         # 遍歷指定文件夾,查找所有 .c 文件  
 97         if mode == 0 or mode == 2:
 98             #print(heard_inc.text)  
 99             heard_data = heard_inc.text + ";"   #末尾需要先加一個分號   
100             
101         for subdir, _, files in os.walk(folder_path):
102             #.h路徑
103             if mode == 0 or mode == 2:
104                 dir_path = os.path.relpath(subdir, start=os.path.dirname(xml_path))
105                 if dir_path in heard_inc.text:
106                     print("需要添加的頭文件路徑已存在本次跳過")
107                 else:
108                     heard_data = heard_data + dir_path + ";"
109                     
110             #.c添加到分組
111             if mode == 0 or mode == 1:
112                 for file in files:     
113                     if file.endswith('.c'):
114                         # 計算相對路徑
115                         file_path = os.path.relpath(os.path.join(subdir, file), start=os.path.dirname(xml_path))
116                         #print("路徑",file_path)
117                         file_check = files_node.findall('File')
118                         if init_creat == 0:
119                             #print("長度",len(file_check))
120                             #遍歷當前分組下的節點,檢測是否已經包含了該路徑,如果有直接跳過
121                             for i in range(len(file_check)):
122                                 if file_path in file_check[i].find("FilePath").text:
123                                     print("節點已存在本次跳過")
124                                     creat_dot = 0
125                                     break
126                                 else: 
127                                     if i == len(file_check) - 1:
128                                         creat_dot = 1
129                                         print("節點不存在,創建節點")
130                                     else:
131                                        creat_dot = 0
132                                     continue    
133                         if creat_dot == 1:
134                             # 創建 File 節點並添加到 Files 節點下
135                             file_node = ET.SubElement(files_node, 'File')
136                             file_name_node = ET.SubElement(file_node, 'FileName')
137                             file_name_node.text = file
138                             file_type_node = ET.SubElement(file_node, 'FileType')
139                             file_type_node.text = '1'  # .c 文件類型都為 1
140 
141                             file_path_node = ET.SubElement(file_node, 'FilePath')
142                             file_path_node.text = file_path
143                             creat_dot = 0
144                             init_creat = 0
145                             
146         if mode == 0 or mode == 2:
147             heard_data = heard_data.rstrip(";") #移除最後一個多加的;
148             heard_inc.text = heard_data
149             #print(heard_inc.text)                    
150                   
151         # 格式化 XML
152         indent(root)
153 
154         # 保存修改後的 XML 文件
155         tree.write(xml_path, encoding='utf-8', xml_declaration=True)
156         print("已完成")
157 
158     except ET.ParseError as e:
159         print(f"ParseError: {e}")
160         with open(xml_path, 'r', encoding='utf-8') as file:
161             lines = file.readlines()
162             start = max(0, e.position[0] - 5)
163             end = min(len(lines), e.position[0] + 5)
164             print("Context around the error:")
165             for i in range(start, end):
166                 print(f"{i+1}: {lines[i].strip()}")
167 
168     finally:
169         # 將文件擴展名改回 .uvprojx
170         os.rename(xml_path, uvprojx_file_path)
171 
172 #尋找工程文件
173 def find_uvprojx_file():
174     uvprojx_files = glob.glob("*.uvprojx")
175     if not uvprojx_files:
176         print("未找到工程文件,請把此文件放在keil工程目錄下")
177         return None
178     elif len(uvprojx_files) > 1:
179         print("在當前目錄中找到多個.uvprojx文件:")
180         for i, file in enumerate(uvprojx_files, start=1):
181             print(f"{i}. {file}")
182         print("請確保目錄中只有一個.uvprojx文件")
183         return None
184     else:
185         return uvprojx_files[0]
186 
187 if __name__ == "__main__":
188     print("keil一鍵添加文件和頭文件路徑腳本\n\
189     需放在keil工程同級目錄下\n\
190     參數格式,參數用空格隔開\n\
191     預設模式:0\n\
192     預設路徑:\"../../../external/lvgl\"\n\
193     預設分組:\"lvgl\"\n\
194     1.添加模式 0:全部添加(.c文件全添加到分組.h文件夾加入include路徑里) 1:只添加.c文件到分組 2:只添加.h文件夾到include里\n\
195     2.要添加的文件夾路徑,請使用相對路徑\n\
196     3.要添加的分組名稱,如果沒有分組需要先去keil手動添加分組\n")
197     
198     param = input("請輸入參數:")
199     
200     if param:
201         #print(param)
202         args = param.split()
203         args[0] = int(args[0])
204         print(args)
205     else:
206         args = [0,"../../../external/lvgl","lvgl"]
207         print("使用預設參數:",args)
208     uvprojx_file_path = find_uvprojx_file()
209     if uvprojx_file_path:
210         add_files_to_group(uvprojx_file_path, args[0],args[1],args[2])
211 
212     event = Event()
213     event.wait()

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Kong和Konga攻堅一、安裝Kong 參考網址:在碼頭工人上安裝孔網關 - v3.3.x |孔文檔 (konghq.com)1、創建自定義 Docker 網路以允許容器發現和 相互溝通: docker network create kong-net您可以根據需要將此網路命名為任何名稱。我們使用 ...
  • 引言 本來博主想偷懶使用AutoUpdater.NET組件,但由於博主項目有些特殊性和它的功能過於多,於是博主自己實現一個輕量級獨立自動更新組件,可稍作修改集成到大家自己項目中,比如:WPF/Winform/Windows服務。大致思路:發現更新後,從網路上下載更新包併進行解壓,同時在 WinFor ...
  • 今天偶然知道一款叫做stylet的MVVM框架,挺小巧的,特別是它的命令觸發方式,簡單粗暴,讓人感覺很巴適,現在我做一個簡單的demo來順便來分享給大家。 本地創建一個WPF項目,此處我使用.NET 8來創建。然後引用stylet最新的nuget包。 然後刪掉App.xaml裡面自帶的啟動項 刪掉以 ...
  • 一:背景 1. 講故事 這些天有點意思,遇到的幾個程式故障都是和Windows操作系統或者第三方組件有關係,真的有點無語,今天就帶給大家一例 IIS 相關的與大家分享,這是一家國企的.NET程式,出現了崩潰急需分析。 二:WinDbg 分析 1. 為什麼會崩潰 崩潰原因相對還是好找的,雙擊dump文 ...
  • 目錄知識補給站對文件描述符集合操作的四個巨集操作伺服器IO多路復用中的select和poll的區別 知識補給站 對文件描述符集合操作的四個巨集操作 對文件描述符集合操作的四個巨集操作在select函數中起著關鍵的作用,它們用於初始化、添加、刪除和檢查文件描述符集合中的元素。這四個巨集為: FD_ZERO、F ...
  • 前言 筆者做過一段時間的車載LiDAR開發,對LidarView開源項目進行過深度定製,摸索了一套LidarView軟體的開發和調試方法 1 軟體安裝 1.1 安裝準備 以Windows10系統平臺為例,依次下載以下工具軟體,軟體(VS、Qt、cdb)的版本很重要!以下版本經過驗證是沒有問題的 序號 ...
  • 前言 最近調試NXP FRDM-MCXN947開發板,發現它的硬體i2c介面讀取的感測器數據老是不對,排查了硬體電路也發現不了啥問題;於是乎想到用邏輯分析儀試一下,果然很快定位到問題所在;還是那句話,用對的工具做對的事情,別浪費時間!這篇文章主要關於邏輯分析儀的使用教程 介紹 nanoDLA 是Mu ...
  • 第一步:下載鏡像文件 百度網盤下載https://pan.baidu.com/s/1efRQGFTbq6Kgw9axLOmWzg?pwd=emxf 第二步:打開Vmware 第三步:進行各項配置 創建新的虛擬機,選擇高級,然後下一步 直接預設下一步 選擇稍後安裝然後下一步 kali屬於Debian系 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...