首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在MS-Word中替换TextBox

在MS-Word中替换TextBox
EN

Stack Overflow用户
提问于 2020-05-12 14:19:01
回答 1查看 30关注 0票数 0

我尝试了这两种方法。一个工作得很好,而另一个却不行。有人能解释一下原因吗?

1-这个成功了

代码语言:javascript
复制
Dim scount As Integer
Dim x As Integer
scount = WordDoc.Shapes.Count
For x = 1 To scount
WordDoc.Shapes(x).Select
If WordDoc.Shapes(x).TextFrame.HasText = True Then
With WordDoc.Shapes(x).TextFrame.TextRange.Find
  .Text = "World"
  .Replacement.Text = "505"
  .Forward = True
  .Wrap = wdFindContinue
  .Execute Replace:=wdReplaceAll
End With
End If
Next x

2-这个不起作用

代码语言:javascript
复制
Dim Shp As Shape

For Each Shp In ActiveDocument.Shapes
  Shp.Select
     With Selection.Find
        .Text = "World"
        .Replacement.Text = "Here"
        .Forward = True
        .Wrap = wdFindContinue
        .Execute Replace:=wdReplaceAll
    End With
Next
EN

回答 1

Stack Overflow用户

发布于 2020-05-12 14:35:23

您的第二个宏不起作用,因为它没有解决TextFrame或TextRange问题。这将会起作用:

代码语言:javascript
复制
Dim Shp As Shape
For Each Shp In ActiveDocument.Shapes
  With Shp
    If .TextFrame.HasText = True Then
      With .TextFrame.TextRange.Find
        .Text = "World"
        .Replacement.Text = "Here"
        .Forward = True
        .Wrap = wdFindContinue
        .Execute Replace:=wdReplaceAll
      End With
    End If
  End With
Next
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61745041

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档