次の方法で共有


Format-List

出力をプロパティごとに新しい行に配置してリスト形式に書式設定します。

構文

Format-List
      [[-Property] <Object[]>]
      [-GroupBy <Object>]
      [-View <string>]
      [-ShowError]
      [-DisplayError]
      [-Force]
      [-Expand <string>]
      [-InputObject <psobject>]
      [<CommonParameters>]

説明

Format-List コマンドレットは、コマンドの出力をプロパティの一覧として書式設定し、各プロパティを個別の行に表示します。 Format-List を使用すると、オブジェクトのすべてのプロパティまたは選択したプロパティを一覧 (Format-List -Property *) として書式設定および表示できます。

テーブルよりもリスト内の各項目に使用できる領域が多いため、PowerShell ではリスト内のオブジェクトのプロパティが多く表示され、プロパティ値が切り捨てられる可能性は低くなります。

例 1: コンピューター サービスの書式設定

Get-Service | Format-List

このコマンドは、コンピューター上のサービスに関する情報をリストとして書式設定します。 既定では、サービスはテーブルとして書式設定されます。 Get-Service コマンドレットは、コンピューター上のサービスを表すオブジェクトを取得します。 パイプライン演算子 (|) は、結果をパイプラインで Format-Listに渡します。 次に、Format-List コマンドは、一覧内のサービス情報を書式設定し、既定の出力コマンドレットに送信して表示します。

例 2: PS1XML ファイルのフォーマット

これらのコマンドは、PowerShell ディレクトリ内の PS1XML ファイルに関する情報を一覧として表示します。

$A = Get-ChildItem $pshome\*.ps1xml
Format-List -InputObject $A

最初のコマンドは、ファイルを表すオブジェクトを取得し、$A 変数に格納します。

2 番目のコマンドでは、Format-List を使用して、$Aに格納されているオブジェクトに関する情報を書式設定します。 このコマンドは、InputObject パラメーターを使用して変数を Format-Listに渡し、書式設定された出力を既定の出力コマンドレットに送信して表示します。

例 3: プロセスプロパティを名前で書式設定する

このコマンドは、コンピューター上の各プロセスの名前、基本優先度、および優先度クラスを表示します。

Get-Process | Format-List -Property Name, BasePriority, PriorityClass

Get-Process コマンドレットを使用して、各プロセスを表すオブジェクトを取得します。 パイプライン演算子 (|) は、プロセス オブジェクトをパイプラインを通して Format-Listまで送ります。 Format-List は、指定したプロパティの一覧としてプロセスを書式設定します。 プロパティのパラメーター名 は省略可能なので、指定しなくてもかまいません。

例 4: プロセスのすべてのプロパティを書式設定する

このコマンドは、Winlogon プロセスのすべてのプロパティを表示します。

Get-Process winlogon | Format-List -Property *

Get-Process コマンドレットを使用して、Winlogon プロセスを表すオブジェクトを取得します。 パイプライン演算子 (|) は、Winlogon プロセス オブジェクトをパイプラインを介して Format-List渡します。 このコマンドでは、Property パラメーターを使用してプロパティを指定し、すべてのプロパティを示す * を指定します。 Property パラメーターの名前は省略可能であるため、省略してコマンドを Format-List *として入力できます。 Format-List は、結果を既定の出力コマンドレットに自動的に送信して表示します。

例 5: 形式エラーのトラブルシューティング

次の例は、式を使用して DisplayError または ShowError パラメーターを追加した結果を示しています。

PC /> Get-Date | Format-List DayOfWeek,{ $_ / $null } -DisplayError

DayOfWeek    : Friday
 $_ / $null  : #ERR

PC /> Get-Date | Format-List DayOfWeek,{ $_ / $null } -ShowError

DayOfWeek    : Friday
 $_ / $null  :

Failed to evaluate expression " $_ / $null ".
+ CategoryInfo          : InvalidArgument: (12/21/2018 7:59:23 AM:PSObject) [], RuntimeException
+ FullyQualifiedErrorId : PSPropertyExpressionError

パラメーター

-DisplayError

このコマンドレットがコマンド ラインにエラーを表示することを示します。 このパラメーターはほとんど使用されませんが、Format-List コマンドで式を書式設定していて、式が機能していないように見える場合は、デバッグ支援として使用できます。

型:SwitchParameter
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-Expand

書式設定されたコレクション オブジェクトとコレクション内のオブジェクトを指定します。 このパラメーターは、System.Collections.ICollection インターフェイスをサポートするオブジェクトを書式設定するように設計されています。 既定値は EnumOnlyです。 このパラメーターに使用できる値は次のとおりです。

  • EnumOnly。 コレクション内のオブジェクトのプロパティを表示します。
  • CoreOnly。 コレクション オブジェクトのプロパティを表示します。
  • Both。 コレクション オブジェクトのプロパティとコレクション内のオブジェクトのプロパティを表示します。
型:String
指定可能な値:CoreOnly, EnumOnly, Both
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-Force

このコマンドレットがすべてのエラー情報を表示することを示します。 DisplayError または ShowError パラメーターを使用します。 既定では、エラー オブジェクトがエラー ストリームまたは表示ストリームに書き込まれると、一部のエラー情報のみが表示されます。

特定の .NET 型を書式設定する場合にも必要です。 詳細については、「Notes」セクションを参照してください。

型:SwitchParameter
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-GroupBy

共有プロパティまたは値に基づいてグループで出力を指定します。 出力の式またはプロパティを入力します。 GroupBy パラメーターは、オブジェクトが並べ替えられていることを想定しています。 Format-List を使用してオブジェクトをグループ化する前に、Sort-Object コマンドレットを使用します。

GroupBy パラメーターの値には、新しい計算プロパティを指定できます。 計算プロパティには、スクリプト ブロックまたはハッシュ テーブルを指定できます。 有効なキーと値のペアは次のとおりです。

  • Name (または Label) - <string>
  • Expression - <string> または <script block>
  • FormatString - <string>

プロパティの詳細については、「about_Calculated_Properties」を参照してください。

型:Object
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-InputObject

書式設定するオブジェクトを指定します。 オブジェクトを含む変数を入力するか、オブジェクトを取得するコマンドまたは式を入力します。

型:PSObject
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:True
ワイルドカード文字を受け取る:False

-Property

表示に表示されるオブジェクト プロパティと表示順序を指定します。 ワイルドカードを使用できます。

このパラメーターを省略した場合、表示に表示されるプロパティは、表示されるオブジェクトによって異なります。 パラメーター名(プロパティ)は省略可能です。 同じコマンドでは、プロパティ パラメーターと View パラメーターを使用することはできません。

Property パラメーターの値には、新しい計算プロパティを指定できます。 計算プロパティには、スクリプト ブロックまたはハッシュ テーブルを指定できます。 有効なキーと値のペアは次のとおりです。

  • Name (または Label) - <string>
  • Expression - <string> または <script block>
  • FormatString - <string>

プロパティの詳細については、「about_Calculated_Properties」を参照してください。

型:Object[]
配置:0
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:True

-ShowError

コマンドレットがパイプラインを介してエラーを送信することを示します。 このパラメーターはほとんど使用されませんが、Format-List コマンドで式を書式設定していて、式が機能していないように見える場合は、デバッグ支援として使用できます。

型:SwitchParameter
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-View

代替リストの形式またはビューの名前を指定します。 同じコマンドでは、プロパティ パラメーターと View パラメーターを使用することはできません。

型:String
配置:Named
規定値:None
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

入力

PSObject

任意のオブジェクトをこのコマンドレットにパイプできます。

出力

Microsoft.PowerShell.Commands.Internal.Format

このコマンドレットは、リストを表す書式オブジェクトを返します。

メモ

Windows PowerShell には、Format-Listの次のエイリアスが含まれています。

  • fl

Format-Listなどの形式コマンドレットは、表示するデータを配置しますが、表示しません。 データは、PowerShell の出力機能と、Out-HostOut-Fileなどの Out 動詞 (Out コマンドレット) を含むコマンドレットによって表示されます。

format コマンドレットを使用しない場合、PowerShell では、表示されるオブジェクトごとに既定の形式が適用されます。

View パラメーターを使用すると、テーブルの代替形式を指定できます。 PowerShell ディレクトリの *.format.PS1XML ファイルで定義されているビューを使用することも、新しい PS1XML ファイルに独自のビューを作成し、Update-FormatData コマンドレットを使用して PowerShell に含めることもできます。

View パラメーターの代替ビューではリスト形式を使用する必要があります。それ以外の場合、コマンドは失敗します。 代替ビューがテーブルの場合は、Format-Tableを使用します。 代替ビューがリストまたはテーブルでない場合は、Format-Customを使用します。

Property パラメーターで Format-List を使用する場合は、次のいずれかの条件で Force パラメーターを含める必要があります。

  • 入力オブジェクトは、ToString() メソッドを使用して帯域外で書式設定されます。 これは、[int][long]など、組み込みの数値型のスーパーセットである [string] および .NET プリミティブ型に適用されます。

  • 入力オブジェクトにはパブリック プロパティがありません。

  • 入力オブジェクトは、成功出力ストリーム以外の出力ストリームに PowerShell が使用するラッパー型のインスタンスです。 これは、これらのラッパー型が成功出力ストリームに送信される場合にのみ適用されます。このためには、まず ErrorVariable や のような一般的なパラメーターを通じてキャプチャするか、または *>&1のようなリダイレクトを使用する必要があります。