批量输出dwg文件中的文本

本文介绍了一种通过编写CAD插件自动从大量dwg文件中提取文本并将其转换为CSV格式的方法,避免了手动复制的繁琐过程。该插件能够筛选特定范围内的文字,并按X坐标排序,实现高效的数据迁移。

  公司来了一批图纸,里面有一部分内容需要复制到excel中,几百张来图每一张都

手工复制,烦死了。编写一个CAD插件,自动导出文本,简单记录在下面。

想法是:

1.输入命令,选择所有dwg文件

2.挨个处理dwg文件,生成同名的txt文件保存文本

基本思路是用Database.ReadDwgFile 读取dwg文件,因为这样可以不用显示文档,可以提高速度;

        [CommandMethod("GetText")]
        public void GetTextCST()
        {
            OpenFileDialog ofd = new OpenFileDialog();
            ofd.Filter = "dwg files (*.dwg)|*.dwg|All files (*.*)|*.*";
            ofd.FilterIndex = 1;
            ofd.RestoreDirectory = true;
            ofd.Multiselect = true;

            if(ofd.ShowDialog()== DialogResult.OK)
                foreach (string fn in ofd.FileNames)
                    try
                    {
                        DoDwg2Csv(fn);
                    }
                    catch
                    {
                        File.AppendAllText("D:\\dwg2csv.txt", DateTime.Now.ToString("yyyy-MM-dd hh-mm-ss") + fn + "\n");
                    }
        }

  

        private void DoDwg2Csv(string fn)
        {
            string csvname = fn + ".csv";
            using (Database db = new Database(false, true))
            {
                db.ReadDwgFile(fn, FileOpenMode.OpenForReadAndAllShare, false, "");
                db.CloseInput(true);

                using (Transaction tr = db.TransactionManager.StartTransaction())
                {
                    // 模型空间
                    BlockTable blkTbl = tr.GetObject(db.BlockTableId, OpenMode.ForRead) as BlockTable;
                    BlockTableRecord modelSpace = tr.GetObject(
                        blkTbl[BlockTableRecord.ModelSpace], 
                        OpenMode.ForRead)
                        as BlockTableRecord;

                    // 遍历模型空间,提取文字                    
                    List<DBText> txts = new List<DBText>();
                    foreach (ObjectId oid in modelSpace)
                    {
                        DBObject dbobj = tr.GetObject(oid, OpenMode.ForRead);
                        if (dbobj is Entity)
                        {
                            Entity entity = dbobj as Entity;
                            string enttype = entity.GetRXClass().Name;
                            if (enttype == "AcDbText")
                            {
                                DBText acText = entity as DBText;
                                if (acText.Position.X < 587 || acText.Position.Y < 115)//指定范围
                                    continue;                                
                                txts.Add( acText );
                            }
                        }//if (dbobj is Entity)
                    }//foreach (ObjectId oid in modelSpace)

                    txts.Sort((t1, t2) => t1.Position.X >= t2.Position.X ? 1 : -1);

                    for (int i = 0; i < txts.Count;i++)
                        File.AppendAllText(csvname, txts[i].TextString+"\r\n", Encoding.Default);
                }//using
            }//using           
        }

  

 

转载于:https://www.cnblogs.com/sinceret/p/10108866.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值