powershell操作word詳解
powershell操作word
我假設(shè)許多讀者用PowerShell生成服務(wù)器、事件以及Windows網(wǎng)絡(luò)上各種數(shù)據(jù)的報表。您也許創(chuàng)建過純文本文件,甚至漂亮的HTML報表。但是您也可以用上Microsoft Word,當(dāng)然,前提是您已經(jīng)安裝了Word。在這個系列的第二部分,我將會向您演示如何用PowerShell為Word文檔套用樣式。
創(chuàng)建Word應(yīng)用程序?qū)ο?BR>PowerShell可以通過COM接口控制Word應(yīng)用程序。有趣的地方是,雖然您可以交互式地做所有的操作,但我希望您最終能夠用腳本操作一切。我們從創(chuàng)建一個Word程序?qū)ο箝_始。
PS C:\> $word=new-object -ComObject "Word.Application"
如果您好奇的話,可以將這個對象輸出到 Get-Member 命令。我們將創(chuàng)建一系列對象,您可以將每一個對象通過管道輸出到 Get-Member 來探索它們。
下一步,我們創(chuàng)建一個文檔對象。
PS C:\> $doc=$word.documents.Add()
現(xiàn)在,Word程序已經(jīng)啟動,并且創(chuàng)建了一個新文檔,但是您在屏幕上看不到任何東西。通常這是正常的,因為我們需要它在后臺運行。但是如果您想查看所創(chuàng)建的文檔,您需要將應(yīng)用程序的 Visible 屬性設(shè)置為 True。
PS C:\> $word.Visible=$True
在我們插入文本之前,我們需要獲取焦點。創(chuàng)建一個 Selection 對象可以幫我們做一些諸如設(shè)置字體大小和顏色等操作,我們將在第二部分介紹這些操作。
PS C:\> $selection=$word.Selection
用PowerShell在文檔中插入文本
現(xiàn)在光標(biāo)在文檔的頂部,現(xiàn)在可以開始插入文本了。我們將用 Selection 對象的 TypeText() 方法插入當(dāng)前的日期和時間。
PS C:\> $selection.TypeText((Get-Date))
如果我們繼續(xù)插入文本,那么文本將會緊挨在日期的后面?,F(xiàn)在我們用 TypeParagraph() 方法插入一個回車符。
PS C:\> $selection.TypeParagraph()
讓我們繼續(xù)插入一些文本。我將用WMI獲取本地計算機(jī)的操作系統(tǒng)信息。
PS C:\> $os=Get-WmiObject -class win32_OperatingSystem
PS C:\> $selection.TypeText("Operating System Information for $($os.CSName)")
由于我希望寫入所有的非系統(tǒng)屬性,所以我將快速遞創(chuàng)建一個數(shù)組用來保存所有的屬性名。
PS C:\> $os.properties | select Name | foreach -begin {$props=@()} -proc {$props+="$($_.name)"}
現(xiàn)在我可以從 $os 獲取所有的屬性并插入Word文檔。很重要的一點是 TypeText() 的值是字符串型的,所以我需要將內(nèi)聯(lián)的PowerShell表達(dá)式通過管道輸出到 Out-String。
PS C:\> $selection.TypeText(($os | Select -Property $props | Out-String))
如果需要的話,還可以繼續(xù)插入文字和圖片。當(dāng)完成操作以后,我將保存并關(guān)閉文檔。
PS C:\> $doc.SaveAs([ref]"c:\work\osreport.docx")
PS C:\> $doc.Close()
請確認(rèn)使用 [ref] 為文件路徑轉(zhuǎn)換數(shù)據(jù)類型。假設(shè)我不再創(chuàng)建新的文檔,那么剩下的就是關(guān)閉Word應(yīng)用程序。
PS C:\> $word.quit()
這些就是要做的所有事情。最終生成的Word文檔是可用的,雖然可能不太漂亮。在我的例子中發(fā)現(xiàn)一個問題:Word用的事非等寬字體,而PowerShell的輸出格式假設(shè)用的是等寬字體。(譯者注:可能會造成輸出的結(jié)果對不整齊)。
第二個示例
$objWord = New-Object -Com Word.Application
$objWord.Visible = $true
$objMissingValue = [System.Reflection.Missing]::Value
$objDocument = $objWord.Documents.Add($objMissingValue, $objMissingValue, $objMissingValue, $objMissingValue)
$objParaHeader = $objDocument.Paragraphs.Add($objMissingValue)
$objParaHeader.Range.Style = "Heading 1"
$objParaHeader.Range.Text = "The power of Microsoft Windows PowerShell"
$objParaHeader.Range.InsertParagraphAfter()
$objParaText = $objDocument.Paragraphs.Add($objMissingValue)
$objParaText.Range.Text = "I will not say I have failed 1000 times; I will say that I have discovered 1000 ways that can cause failure – Thomas Edison."
$objParaText.Range.InsertParagraphAfter()
$filename = 'C:\\Script\\PowerShell-Example.doc'
$objDocument.SaveAs($filename,
$objMissingValue, $objMissingValue,
$objMissingValue, $objMissingValue,
$objMissingValue, $objMissingValue,
$objMissingValue, $objMissingValue,
$objMissingValue, $objMissingValue)
##Once the script has added all of the required content the document should be closed:
$objDocument.Close()
$objWord.Quit()
相關(guān)文章
Powershell創(chuàng)建簡潔的HTML報告例子
這篇文章主要介紹了Powershell創(chuàng)建簡潔的HTML報告例子,本文先是講解了實現(xiàn)的步驟,然后給出了實現(xiàn)代碼,需要的朋友可以參考下2014-11-11
powershell解決win10開始菜單和通知中心無法打開
這篇文章主要介紹了powershell解決win10開始菜單和通知中心無法打開的相關(guān)資料,需要的朋友可以參考下2015-10-10
PowerShell 讀取性能計數(shù)器二進(jìn)制文件(.blg)記錄并匯總計算
由于監(jiān)控及報告需要,要統(tǒng)計性能計數(shù)器每天數(shù)值情況,確認(rèn)數(shù)據(jù)庫服務(wù)器的運行狀況。若打開計數(shù)器填寫,比較麻煩,現(xiàn)在統(tǒng)計用 powershell 來讀取計數(shù)器的值2016-11-11
PowerShell數(shù)組結(jié)合switch語句產(chǎn)生的奇特效果介紹
這篇文章主要介紹了PowerShell數(shù)組結(jié)合switch語句產(chǎn)生的奇特效果介紹,產(chǎn)生了類似枚舉的效果,需要的朋友可以參考下2014-08-08
Windows Powershell 命令集 cmdlets
在Windows PowerShell中,需要使用cmdlet執(zhí)行指令。一個cmdlet代表著可操作某一對象的功能命令,cmdlet可使用"動詞-名詞"形式的語法:一個動詞和一個名詞,中間使用連字符連接,例如get-service和start-service。2014-09-09
使用PowerShell實現(xiàn)定時播放視頻和音頻文件
PowerShell是Windows操作系統(tǒng)中強(qiáng)大的腳本語言和自動化工具,這篇文章主要介紹了如何使用PowerShell定時播放視頻和音頻,以及演示一個使用PotPlayer播放器的示例腳本,需要的可以參考一下2023-08-08
PowerShell中使用Filter來創(chuàng)建管道輸入函數(shù)
這篇文章主要介紹了PowerShell中使用Filter來創(chuàng)建管道輸入函數(shù),Filter創(chuàng)建的函數(shù)跟Function創(chuàng)建的函數(shù),在本質(zhì)上是一樣的,需要的朋友可以參考下2014-07-07
自動設(shè)置安卓手機(jī)wifi代理的PowerShell腳本
這篇文章主要介紹了自動設(shè)置安卓手機(jī)wifi代理的PowerShell腳本,幫助大家進(jìn)行抓包測試,感興趣的朋友可以了解下2020-10-10

