找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 819|回复: 3

[讨论]:如何用VBA实现排版?

[复制链接]

已领礼包: 181个

财富等级: 日进斗金

发表于 2002-11-22 18:59:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
要求:在Word中排版后,利用VBA,自动在CAD按排版格式生成文本。示例如下:

  1.   [FONT=courier new]

  2. Sub WordTest()
  3.     On Error Resume Next
  4.     Dim wdApp As Word.Application
  5.     Set wdApp = GetObject(, "Word.Application")
  6.     If Err.Number <> 0 Then Exit Sub
  7.     Dim s As String
  8.     Dim p As Word.Paragraph
  9.     Dim sFont As String
  10.     '枚举所有的段落
  11.     For Each p In wdApp.ActiveDocument.Paragraphs
  12.         sFont = p.Range.Font.Name '这一段落所用的字体
  13.         s = s & "{\f" & sFont & ";" & p.Range.Text & "}" & "\P"
  14.     Next
  15.     s = Left(s, Len(s) - 2)
  16.     Dim iPt(0 To 2) As Double
  17.     iPt(0) = 0: iPt(1) = 0: iPt(2) = 0
  18.     '生成多行文本
  19.     Dim mTextObj As AcadMText
  20.     Set mTextObj = ThisDrawing.ModelSpace.AddMText(iPt, 100, s)
  21.     Set mTextObj = Nothing
  22.     Set p = Nothing
  23.     Set wdApp = Nothing
  24. End Sub
  25.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 181个

财富等级: 日进斗金

 楼主| 发表于 2002-11-25 11:18:40 | 显示全部楼层
在上一次应用到了字体的设置,但在Word排版中还有每一个段落首行缩进两个字符,这怎么设置呢?可以用Paragraph对象的CharacterUnitFirstLineIndent属性来设置,该值如果为正的整数,就表示缩进的字符数。修改如下:

  1.   [FONT=courier new]
  2. Dim sSpace As String
  3. If p.CharacterUnitFirstLineIndent > 0 Then sSpace = Space(p.CharacterUnitFirstLineIndent * 2)
  4. s = s & "{\f" & sFont & ";" & sSpace & p.Range.Text & "}" & "\P"
  5.   [/FONT]


Paragraph对象的FirstLineIndent也控制着缩进的长度,但是以厘米为单的,可以用CentimetersToPoints函数转换成磅为单位。1 厘米 = 28.35 磅。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 181个

财富等级: 日进斗金

 楼主| 发表于 2002-11-25 12:46:02 | 显示全部楼层
对于段落文字的对齐方式,可以用Paragraph对象的Alignment属性来设置,可设成wdAlignParagraphLeft、wdAlignParagraphCenter、wdAlignParagraphRight,分别表示左对齐、中间对齐和右对齐。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2007-1-13 09:46:26 | 显示全部楼层
有些符号没有办法在VBA中输入,怎么样在VBA中新建DOC文档时自动使用自建的样板文件那,又怎么样才能让我想要的VBA中的变量的值赋到DOC中我想要的位置那,
请版主再指教一下,谢谢先
执行2楼的语句
Dim wdApp As Word.Application
提示,用户定义类型未定义,这是为什么啊?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-28 13:18 , Processed in 0.336183 second(s), 37 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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