パイプライン入力 1 - ByValue
概要
CommandletA | CommandletB
- PowerShellでパイプで値を渡す方法は2つある。ByValue と ByPropertyName。
- ByValueがデフォルトで、PowerShellはパイプからByValueな値がないか調べて、ない場合はByPropertyNameな値を調べる。どちらもない場合はエラーになる。
- ここではByValueについて説明する。
ByValue 例1
例
PS> "1.txt","2.txt","3.txt" | Invoke-Item
- この例ではカレントディレクトリに1.txtや2.txtというファイルがあって、それをInvoke-Itemに渡して、メモ帳などで開く場合を考える。
"1.txt","2.txt","3.txt" がどんな値を出力するかGet-Memberで調べる
PS> "1.txt","2.txt","3.txt" | Get-Member
TypeName: System.String
Invoke-Itemがどんなパイプライン入力を受け取るかHelpで調べる
PS> help Invoke-Item -Full
-Path <String[]>
Specifies the path to the selected item.
必須 true
位置 0
既定値 None
パイプライン入力を許可する True (ByPropertyName, ByValue)
ワイルドカード文字を許可する false
- 「-Path」が「ByValue」で「パイプライン入力を許可する True」なことが分かる。
- そして、-Pathが受け取るのは「String[]」。
- よって、Invoke-Itemは"1.txt","2.txt","3.txt"を受け取れ、このパイプ処理は正常に動作する。
ByValue 例2
例
PS> Get-Process notepad* | Stop-Process
- この例ではメモ帳(notepad.exe)を起動している状態で、それをStop-Processで終了する場合を考える。
Get-Process がどんな値を出力するかGet-Memberで調べる
PS> Get-Process | gm
TypeName: System.Diagnostics.Process
Stop-Processがどんなパイプライン入力を受け取るかHelpで調べる
PS> help Stop-Process -full
-InputObject <Process[]>
Specifies the process objects to stop. Enter a variable that contains the objects, or type a command or expression that gets the objects.
必須 true
位置 0
既定値 None
パイプライン入力を許可する True (ByValue)
ワイルドカード文字を許可する false
- Stop-ProcessがProcessをByValueで受け取ることがわかる。
- よって、このパイプ処理は正常に動作する。
ByValue 例3
例
PS> gc .\files.csv
No,Filename
1,a.txt
2,b.txt
3,c.txt
- files.csvというCSVファイルがあって、そこに書かれたa.txtやb.txtをInvoke-Itemに渡して、メモ帳などで開く場合を考える。
Import-Csvがどんな値を出力するかGet-Memberで調べる
PS> Import-Csv .\files.csv | gm
TypeName: System.Management.Automation.PSCustomObject
- Import-CsvはPSCustomObjectを出力する。よって、このままではInvoke-Itemは受け取れない。
Import-Csvの出力からFilenameだけをselectしてみる
PS> Import-Csv .\files.csv | select Filename
Filename
--------
a.txt
b.txt
c.txt
PS> Import-Csv .\files.csv | select Filename | gm
TypeName: Selected.System.Management.Automation.PSCustomObject
- select Filenameでファイル名だけ取り出せているように見えるが、Get-Memberで調べると、型はPSCustomObjectのまま。このままではInvoke-Itemは受け取れない。
select -ExpandPropertyでプロパティだけ取り出す
PS> Import-Csv .\files.csv | select -ExpandProperty Filename
a.txt
b.txt
c.txt
PS> Import-Csv .\files.csv | select -ExpandProperty Filename | gm
TypeName: System.String
PS> Import-Csv .\files.csv | select -ExpandProperty Filename | Invoke-Item
- このような場合、select -ExpandPropertyを使う。すると、その出力はStringになる。
- これによって、このパイプ処理は正常に動作する。
参考