Python实现批量翻译CAD图纸
更新时间:2023年12月07日 09:42:12 作者:mYlEaVeiSmVp
这篇文章主要为大家详细介绍了如何通过Python实现批量翻译CAD图纸,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以学习一下
程序实现:
读取当前目录以及子文件夹内的dxf文件,首先会把图块分解成线条,然后参照3.xlsx内的原文以及译文进行翻译写入(3.xlsx文件第一列保存原文,第二列保存译文)。
编程技术技术有限,有一些功能没有实现。
进行翻译之前需要自己将dwg图纸转换成dxf图纸,翻译好之后也需要自己再转换成dwg文件(仅尝试过2010版本文件,2018版本貌似会乱码)
另外附一个能从dxf文件中提取原文的程序,以便翻译。
实现翻译的的代码:
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, # 设置字体大小 'color': 1 # 设置颜色为红色 }) 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()
实现提取原文的代码:
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()
到此这篇关于Python实现批量翻译CAD图纸的文章就介绍到这了,更多相关Python翻译CAD图纸内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
如何使用 Python和 FFmpeg 批量截图视频到各自文件夹中
wxPython 提供了一个简单易用的界面,而 FFmpeg 则负责处理视频帧的提取,这个工具不仅对视频编辑工作有帮助,也为批量处理视频文件提供了极大的便利,这篇文章主要介绍了使用 Python和 FFmpeg 批量截图视频到各自文件夹中,需要的朋友可以参考下2024-08-08python框架Django实战商城项目之工程搭建过程图文详解
这篇文章主要介绍了python框架Django实战商城项目之工程搭建过程,这个项目很像京东商城,项目开发采用前后端不分离的模式,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下2020-03-03
最新评论