Python實現(xiàn)批量翻譯CAD圖紙
程序?qū)崿F(xiàn):
讀取當前目錄以及子文件夾內(nèi)的dxf文件,首先會把圖塊分解成線條,然后參照3.xlsx內(nèi)的原文以及譯文進行翻譯寫入(3.xlsx文件第一列保存原文,第二列保存譯文)。
編程技術(shù)技術(shù)有限,有一些功能沒有實現(xiàn)。
進行翻譯之前需要自己將dwg圖紙轉(zhuǎn)換成dxf圖紙,翻譯好之后也需要自己再轉(zhuǎn)換成dwg文件(僅嘗試過2010版本文件,2018版本貌似會亂碼)
另外附一個能從dxf文件中提取原文的程序,以便翻譯。
實現(xiàn)翻譯的的代碼:
import os import pandas as pd import ezdxf from pathlib import Path def load_translation_map(excel_path): df = pd.read_excel(excel_path) return dict(zip(df.iloc[:, 0], df.iloc[:, 1])) def translate_text_entity(msp, entity, translation_map): original_text = entity.dxf.text translated_text = translation_map.get(original_text) if translated_text: msp.add_text(translated_text, dxfattribs={ 'insert': (entity.dxf.insert[0], entity.dxf.insert[1] - 0.75), 'height': 1, # 設(shè)置字體大小 'color': 1 # 設(shè)置顏色為紅色 }) def translate_dwg(dwg_path, translation_map): doc = ezdxf.readfile(dwg_path) msp = doc.modelspace() # 翻譯模型空間中的文本 for entity in msp.query('TEXT MTEXT'): translate_text_entity(msp, entity, translation_map) # 翻譯塊中的文本 for block in doc.blocks: for entity in block.query('TEXT MTEXT'): translate_text_entity(msp, entity, translation_map) return doc def process_directory(directory, translation_map, output_folder): for root, dirs, files in os.walk(directory): # 跳過translated_drawings文件夾 dirs[:] = [d for d in dirs if d != output_folder.name] for name in files: if name.endswith('.dxf'): file_path = Path(root) / name relative_path = file_path.relative_to(directory) output_path = output_folder / relative_path output_path.parent.mkdir(parents=True, exist_ok=True) print(f"Processing file: {file_path}") doc = translate_dwg(file_path, translation_map) doc.saveas(str(output_path)) print(f"File saved: {output_path}") def main(): translation_map = load_translation_map('3.xlsx') source_folder = Path('.') # Current directory output_folder = Path('translated_drawings') output_folder.mkdir(exist_ok=True) process_directory(source_folder, translation_map, output_folder) if __name__ == "__main__": main()
實現(xiàn)提取原文的代碼:
import os import pandas as pd import ezdxf from pathlib import Path def extract_text_from_dxf(file_path): try: doc = ezdxf.readfile(file_path) msp = doc.modelspace() texts = [] # 提取模型空間中的文本 for entity in msp.query('TEXT MTEXT'): texts.append(entity.dxf.text) # 提取塊中的文本 for block in doc.blocks: for entity in block.query('TEXT MTEXT'): texts.append(entity.dxf.text) return texts except IOError: print(f"Could not read file: {file_path}") return [] except ezdxf.DXFStructureError: print(f"Invalid or corrupted DXF file: {file_path}") return [] def process_directory(directory): all_texts = [] for root, dirs, files in os.walk(directory): for name in files: if name.endswith('.dxf'): file_path = Path(root) / name texts = extract_text_from_dxf(file_path) for text in texts: all_texts.append([file_path, text]) return all_texts def main(): directory = Path('.') # 當前目錄 texts = process_directory(directory) # 將提取的文本保存到Excel文件中 df = pd.DataFrame(texts, columns=['File Path', 'Text']) df.to_excel('extracted_texts.xlsx', index=False) print("Texts have been extracted and saved to 'extracted_texts.xlsx'.") if __name__ == "__main__": main()
到此這篇關(guān)于Python實現(xiàn)批量翻譯CAD圖紙的文章就介紹到這了,更多相關(guān)Python翻譯CAD圖紙內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python中numpy數(shù)組與list相互轉(zhuǎn)換實例方法
在本篇文章里小編給大家整理的是一篇關(guān)于python中numpy數(shù)組與list相互轉(zhuǎn)換實例方法,對此有興趣的朋友們可以學(xué)習(xí)下。2021-01-01python?plotly設(shè)置go.Scatter為實線實例
這篇文章主要為大家介紹了python?plotly設(shè)置go.Scatter為實線線條的樣式實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-10-10使用pycallgraph分析python代碼函數(shù)調(diào)用流程以及框架解析
這篇文章主要介紹了使用pycallgraph分析python代碼函數(shù)調(diào)用流程以及框架解析,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03Python編程深度學(xué)習(xí)計算庫之numpy
今天小編就為大家分享一篇關(guān)于Python編程深度學(xué)習(xí)計算庫之numpy,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12