使用 Powershell 在 MS Word 中编辑文本表单字段

问题描述 投票:0回答:2

我正在尝试编写一个在 Microsoft Office Word 2007 中编辑文本表单字段的 Powershell 脚本。它应该通过我之前配置的书签找到一个表单字段,并在其中写入一个文本。我出于测试目的写入的默认文本是“Something”。 这就是我到目前为止所拥有的:

$document = 'D:\Powershell\Test.docx'
$Word = New-Object -Com Word.Application
$Word.Visible = $True
$doc = $word.Documents.Open($document)
$text = "Hello"
$bookmark = "server1"
$doc.Bookmarks.Item($bookmark).Range.Text.Replace("Something", $text)

虽然它在控制台中工作,因为输出是:

FORMTEXT Hello

Word仍然显示我之前手动插入的字符串。 当我输入:

$doc.Bookmarks.Item($bookmark).Range.Text

输出为:

FORMTEXT Something

我已经尝试过:

$Word.ActiveDocument.Reload()
$Word.ActiveDocument.Fields.Update()
$doc.PrintPreview()
$doc.ClosePrintPreview()
$doc.Bookmarks.Item($bookmark).Range.Fields.Update()

但似乎没有任何作用。 有人知道如何在文本表单字段中永久写入内容吗? 或者,如果这更容易,我可以使用(丰富的)文本内容控件(似乎更新)。它们不使用书签,而是使用标签和标题。 感谢您提前提供帮助。 PS:它也不适用于 MS Word 2016。

powershell ms-word bookmarks form-fields
2个回答
3
投票

当您有旧文本表单字段时,书签确实可以识别该字段。如果您尝试在 VBA 中编写替换书签的文本(例如),您可能会收到错误 6028 -“无法删除范围”。

我不太了解 Powershell,无法在不检查的情况下执行此操作,但等效的 VBA 是

doc.FormFields($bookmark).Result = "Something"

所以我猜 powershell 是这样的

$doc.FormFields.Item($bookmark).Result = "Something"

0
投票

万一Word文档没有书签,您也可以根据表单字段的索引设置值

$document = 'D:\Powershell\Test.docx'
$word = New-Object -Com Word.Application

$doc = $word.Documents.Open($document)
$doc.FormFields[1].Result = (Get-Date).ToString("dd.MM.yyy")
$doc.FormFields[2].Result = "Something" 
$doc.FormFields[3].CheckBox.Value = $True
# ComboBox controls are different
$doc.ContentControls[4].Range.Text = $doc.ContentControls[4].DropdownListEntries[2]
$doc.ContentControls[4].Range.Text = "" # deletes the selection
© www.soinside.com 2019 - 2024. All rights reserved.