求助 VBA中如何求得多行字的实际内容
在的使用中,不免要使用多行文字,但多行文字在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
差距比较遥远,大家有什么好办法呢?
求助 VBA中如何求得多行字的实际内容
转过去的链接中大家讨论得已经比较详细了,我比较喜欢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来替换的自定义函数
Public Function ReplaceByRegExp(ByVal Mystrig As String, ByVal TxtFind As String, ByVal TxtReplace As String)
Dim RE As Object
Set RE = ThisDrawing.Application.GetInterfaceObject("Vbscript.RegExp")
RE.IgnoreCase = False
RE.Global = True
RE.Pattern = TxtFind
ReplaceByRegExp = RE.Replace(Mystrig, TxtReplace)
Set RE = Nothing
End Function第二个是用来清除多行字格式的函数
Public Function MtextStringClearFormat(ByVal MyString As String) As String
MyString = ReplaceByRegExp(MyString, "\\{", Chr(1))
MyString = ReplaceByRegExp(MyString, "\\}", Chr(2))
MyString = ReplaceByRegExp(MyString, "\\\", Chr(3))
MyString = ReplaceByRegExp(MyString, "\\S([^;]*?)(\^|#)([^;]*?);", "$1$3")
MyString = ReplaceByRegExp(MyString, "\\S([^;]*?);", "$1")
MyString = ReplaceByRegExp(MyString, "(\\P|\\O|\\o|\\L|\\l|\{|\})", "")
MyString = ReplaceByRegExp(MyString, "\\[^;]*?;", "")
MyString = ReplaceByRegExp(MyString, "\x01", "{")
MyString = ReplaceByRegExp(MyString, "\x02", "}")
MyString = ReplaceByRegExp(MyString, "\x03", "")
MtextStringClearFormat = Trim(MyString)
End Function最后写一个测试过程
Sub TEST()
Dim TxtOld As String
Dim TxtNew As String
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"
TxtNew = MtextStringClearFormat(TxtOld)
End Sub大家再帮我用其它的字符串测试一下,看看是不是有所遗漏或是BUG,谢谢了
编了一些自己常用到的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
这样的语句来引用。
请问要如何列出文件中的所有单行文字与多行文字的内容信息。
能不能给段完整代码?
页:
[1]