Windows Powershell匯出管道結果_PowerShell

來源:互聯網
上載者:User

可以將管道的結果轉換成文本輸出,預設是Out-Default。可以通過Get-Command -verb out查看Powershell都有哪些輸出的命令。

複製代碼 代碼如下:

PS C:PowerShell> get-command -Verb out

CommandType Name         Definition
----------- ----         ----------
Cmdlet      Out-Default  Out-Default [-InputObject ]
Cmdlet      Out-File     Out-File [-FilePath]  [[-Encoding]
Cmdlet      Out-GridView Out-GridView [-InputObject ]
Cmdlet      Out-Host     Out-Host [-Paging] [-InputObject ]
Cmdlet      Out-Null     Out-Null [-InputObject ] [-Verbose]
Cmdlet      Out-Printer  Out-Printer [[-Name] ] [-InputObject
Cmdlet      Out-String   Out-String [-Stream] [-Width ]
Out-Default 將輸出發送到預設的格式化程式和預設的輸出 cmdlet。
Out-File 將輸出發送到檔案。
Out-GridView 將輸出發送到單獨視窗中的互動表。
Out-Host 將輸出發送到命令列。
Out-Null 刪除輸出,不將其發送到控制台。
Out-Printer 將輸出發送到印表機。
Out-String 將對象作為一列字串發送到主機。

吸收輸出結果

有的命令無論執行成功或失敗都會有輸出,有時不需要這些輸出時可以使用 | Out-Null,這條命令的作用和 >$null 一樣。尤其在函數中使用比較多,因為如果沒有特別指明return 。Powershell函數會把輸出結果作為函數的傳回值。為了避免這種麻煩,通常在管道後加一條命令Out-Null 或 >$null吸收輸出結果。

複製代碼 代碼如下:

PS C:PowerShell> md ABC

    目錄: C:PowerShell

Mode                LastWriteTime     Length Name
----                -------------     ------ ----
d----        2011/12/19     17:05            ABC

PS C:PowerShell> md ABD >$null
PS C:PowerShell> md ABE | Out-Null

修改管道格式

之前討論過,Powershell預設會在每行命令的末尾追加一條Out-Default,Out-Default預設包含了一條Out-Host,那是不是Out-Host就是英雄無用武之地了。事實上,可以通過Out-Host控制管道的版式。
Powershell不但會自動把管道結果發送到輸出裝置上,而且還會把管道結果轉換成可讀的文本。這個自動轉換與Format-Table有點像。但是完全依靠自動轉換有時會碰到很奇怪的輸出結果。
例如當單獨使用Get-Service時,結果會以表格的形式輸出,但是使用pwd;Get-Service時Service資訊以列表形式輸出。

複製代碼 代碼如下:

PS C:PowerShell> Get-Service

Status   Name               DisplayName
------   ----               -----------
Running  AdobeARMservice    Adobe Acrobat Update Service
Stopped  AeLookupSvc        Application Experience
Stopped  ALG                Application Layer Gateway Service

PS C:PowerShell> pwd;Get-Service

Path
----
C:PowerShell

Status      : Stopped
Name        : THREADORDER
DisplayName : Thread Ordering Server

Status      : Running
Name        : TrkWks
DisplayName : Distributed Link Tracking Client

第二行使用了兩條命令,通過分號間隔。但是為什麼Service資訊會以列表顯示 呢?因為經過Powershell的解譯器處理,上面例子中的第二條命令會變成:
& { pwd;Get-Service} | Out-Default
Powershell在命令中沒有發現特別指定的版式資訊,就會嘗試從第一條命令的第一個結果對象中尋找線索。並且把這種版式強加給緊接著的其它命令。
怎樣避免上述問題,最好的辦法就是要明確指定。
pwd;Get-Service | Out-Host

強制以文本顯示

Powershell的文本轉換一般發生在管道的末尾,但是如果需要對文本處理可是強制轉換成文本。

複製代碼 代碼如下:

PS C:PowerShell> ls . -Recurse | Out-String

 目錄: C:PowerShell

Mode         LastWriteTime   Length Name
----         -------------   ------ ----
d---- 2011/12/19     17:05          ABC
d---- 2011/12/19     17:06          ABD
d---- 2011/12/19     17:06          ABE
d---- 2011/11/29     18:21          myscript
-a--- 2011/12/19     11:31      500 a.html

PS C:PowerShell> (ls | Out-String -Stream).gettype()
IsPublic IsSerial Name     BaseType
-------- -------- ----     --------
True     True     Object[] System.Array

Excel匯出對象

管道結果匯出為文字檔看起來不規整,越讀起來也不方便。所以最好匯出為Excel格式“csv”,這樣的檔案預設支援Microsft Excel程式開啟,並處理。

複製代碼 代碼如下:

PS C:PowerShell> Get-Service | Export-Csv a.csv
PS C:PowerShell> .a.csv

使用這些匯出命令時,切忌不要在管道中使用Format-Table,否則匯出的結果不正常,自己可以測試。那怎樣選擇屬性呢?可是使用Select-Object。

Html匯出對象

Html匯出對象和Excel匯出大同小異。

複製代碼 代碼如下:

PS C:PowerShell> Get-Service | ConvertTo-Html -Title "ls result" | Out-File a.html
PS C:PowerShell> .a.html

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.