明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2137|回复: 4

求助 VBA中如何求得多行字的实际内容

[复制链接]
发表于 2009-9-30 13:13:00 | 显示全部楼层 |阅读模式

AutoCAD的使用中,不免要使用多行文字,但多行文字在VBA编程时有些问题却令我头昏脑胀,如下图

图中所示为一个多行文字,选中它然后使用TEXTSTRING属性,返回一组字符串如下:

\A1;{\H1.6x;\{A}\P{\LB}\P{\H1.6x;C;}\P{\fCorbel|b0|i0|c0|p34;D}\P{\C1;E}\PF\PG

其实这串字符串并不是给我们看的,而是针对CAD文字编辑器的,其中"\"是转义符,以标明多行字所使用的格式

例如:\P表示转行

      \A1;表示文字对齐的样式

。。。。。这里就不一一详述了,有兴趣的朋友可以在网上搜搜看,问题是否串字符串并不是我所需要的,我想要的是

{ABC;DEFG

差距比较遥远,大家有什么好办法呢?

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2009-9-30 23:57:00 | 显示全部楼层
 楼主| 发表于 2009-10-3 12:03:00 | 显示全部楼层
转过去的链接中大家讨论得已经比较详细了,我比较喜欢mccad大虾的思路,但是我觉得他所提供的函数中有一点点瑕疵,最起码我用
"\A1;\{{\H1.6x;A}\P{\LB}\P{\H1.6x;C;}\P\pi0.999306,l2.99792,t7;{\fCorbel|b0|i0|c0|p34;D}\P\pi0,l0,tz;{\C1;E}\PF?\PG\\\Ph{\H0.7x;\S1/2;}\PJ{\H0.7x;\S2^;}\PK{\H0.7x;\S^2;}|\PL"
这个字符串作核试验的时候就不完全正确,而且稍显繁复,所以我重新总结了一下,得出下面的两个函数,请众位同好不吝指正
第一个是用RegExp来替换的自定义函数
  1. Public Function ReplaceByRegExp(ByVal Mystrig As String, ByVal TxtFind As String, ByVal TxtReplace As String)
  2.      Dim RE As Object
  3.      Set RE = ThisDrawing.Application.GetInterfaceObject("Vbscript.RegExp")
  4.      
  5.      RE.IgnoreCase = False
  6.      RE.Global = True
  7.      
  8.      RE.Pattern = TxtFind
  9.      ReplaceByRegExp = RE.Replace(Mystrig, TxtReplace)
  10.      Set RE = Nothing
  11.      
  12. End Function
第二个是用来清除多行字格式的函数
  1. Public Function MtextStringClearFormat(ByVal MyString As String) As String
  2.     MyString = ReplaceByRegExp(MyString, "\\{", Chr(1))
  3.     MyString = ReplaceByRegExp(MyString, "\\}", Chr(2))
  4.     MyString = ReplaceByRegExp(MyString, "\\\", Chr(3))
  5.     MyString = ReplaceByRegExp(MyString, "\\S([^;]*?)(\^|#)([^;]*?);", "$1$3")
  6.     MyString = ReplaceByRegExp(MyString, "\\S([^;]*?);", "$1")
  7.     MyString = ReplaceByRegExp(MyString, "(\\P|\\O|\\o|\\L|\\l|\{|\})", "")
  8.     MyString = ReplaceByRegExp(MyString, "\\[^;]*?;", "")
  9.     MyString = ReplaceByRegExp(MyString, "\x01", "{")
  10.     MyString = ReplaceByRegExp(MyString, "\x02", "}")
  11.     MyString = ReplaceByRegExp(MyString, "\x03", "")
  12.     MtextStringClearFormat = Trim(MyString)
  13. End Function
最后写一个测试过程
  1. Sub TEST()
  2.     Dim TxtOld As String
  3.     Dim TxtNew As String
  4.     TxtOld = "\A1;\{{\H1.6x;A}\P{\LB}\P{\H1.6x;C;}\P\pi0.999306,l2.99792,t7;{\fCorbel|b0|i0|c0|p34;D}\P\pi0,l0,tz;{\C1;E}\PF?\PG\\\Ph{\H0.7x;\S1/2;}\PJ{\H0.7x;\S2^;}\PK{\H0.7x;\S^2;}|\PL"
  5.     TxtNew = MtextStringClearFormat(TxtOld)
  6.    
  7. End Sub
大家再帮我用其它的字符串测试一下,看看是不是有所遗漏或是BUG,谢谢了
发表于 2009-10-5 21:34:00 | 显示全部楼层

编了一些自己常用到的CAD相关的函数,刚好有这个从MText提取文本的。我是在WinXPSP2+VB6SP4+CAD2006下调试的,可能有BUG也说不定。如果觉得能用上就下载吧。使用方法如下面这个函数:

Sub test()
Dim a As Object, strTmp$

    Set a = CreateObject("ZWCADComm.ZWCADPublic")

    strTmp = a.GetTextFromMText("\A1;{\H1.6x;\{A}\P{\LB}\P{\H1.6x;C;}\P{\fCorbel|b0|i0|c0|p34;D}\P{\C1;E}\PF\PG")
End Sub

也可以在工程中引用,然后用

dim a as new ZWCADComm.ZWCADPublic

这样的语句来引用。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2010-5-7 08:12:00 | 显示全部楼层

请问要如何列出文件中的所有单行文字与多行文字的内容信息。

能不能给段完整代码?

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-26 00:25 , Processed in 0.160138 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表