次の方法で共有


Get-History

現在のセッション中に入力したコマンドの一覧を取得します。

構文

Get-History
   [[-Id] <Int64[]>]
   [[-Count] <Int32>]
   [<CommonParameters>]

説明

Get-History コ マンドレットは、セッションの履歴、つまり、現在のセッション中に入力したコマンドの一覧を取得します。

PowerShell では、各セッションの履歴が自動的に保持されます。 セッション履歴に保持されるエントリの数は、$MaximumHistoryCount ユーザー設定変数の値によって決まります。 Windows PowerShell 3.0 以降、既定値は 4096 です。

セッション履歴は XML 形式または CSV 形式で保存できます。 既定では、履歴ファイルはホーム ディレクトリに保存されますが、任意の場所にファイルを保存することができます。

PowerShell の履歴機能の詳細については、「Microsoft Docsのabout_History」を参照してください。

例 1: セッション履歴を取得する

Get-History

このコマンドは、セッション履歴のエントリを取得します。 既定の表示には、各コマンドとその ID が表示されます。これは、実行された順序を示します。

例 2: 文字列を含むエントリを取得する

Get-History | Where-Object {$_.CommandLine -like "*Service*"}

このコマンドは、文字列サービスを含むコマンド履歴のエントリを取得します。 最初のコマンドは、セッション履歴のすべてのエントリを取得します。 パイプライン演算子 (|) は、結果を Where-Object コマンドレットに渡します。これにより、サービスを含むコマンドのみが選択されます。

例 3: 最大 7 つのエントリをエクスポートする

Get-History -ID 7 -Count 5 | Export-Csv History.csv

このコマンドは、エントリ 7 で終わる最新の 5 つの履歴エントリを取得します。 パイプライン演算子は、結果を Export-Csv コマンドレットに渡します。これにより、履歴はコンマ区切りのテキストとして書式設定され、History.csv ファイルに保存されます。 このファイルには、履歴をリストとして書式設定するときに表示されるデータが含まれます。 これには、コマンドの状態と開始時刻と終了時刻が含まれます。

例 4: 最新のコマンドを表示する

Get-History -Count 1

このコマンドは、コマンド履歴の最後のコマンドを取得します。 最後のコマンドは、最後に入力したコマンドです。 このコマンドでは 、Count パラメーターを使用して、1 つのコマンドのみを表示します。 既定では、Get-History は最近使用したコマンドを取得します。 このコマンドは "h -c 1" と省略でき、上方向キーを押すことと同等です。

例 5: 履歴内のエントリのすべてのプロパティを表示する

Get-History | Format-List -Property *

このコマンドは、セッション履歴内のエントリのすべてのプロパティを表示します。 パイプライン 演算子は 、Get-History コマンドの結果を Format-List コマンドレットに渡します。これにより、各履歴エントリのすべてのプロパティが表示されます。 これには、コマンドの ID、状態、開始時刻と終了時刻が含まれます。

パラメーター

-Count

このコマンドレットが取得する最新の履歴エントリの数を指定します。 既定では、 Get-History はセッション履歴内のすべてのエントリを取得します。 コマンドに CountId の両方のパラメーターを使用した場合、表示は Id パラメーターで指定されたコマンドで終了します。

Windows PowerShell 2.0 では、Get-History は既定で最新の 32 個のエントリを取得します。

Type:Int32
Position:1
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Id

セッション履歴内のエントリの ID の配列を指定します。 Get-History は、指定されたエントリのみを取得します。 コマンドに IdCount の両方のパラメーターを使用した場合、Get-History は、Id パラメーターで指定されたエントリで終了する最新のエントリを取得します。

Type:Int64[]
Position:0
Default value:None
Required:False
Accept pipeline input:True
Accept wildcard characters:False

入力

Int64

履歴 ID をこのコマンドレットにパイプできます。

出力

HistoryInfo

このコマンドレットは、取得する履歴項目ごとに履歴オブジェクトを返します。

メモ

  • セッション履歴は、セッション中に入力したコマンドの一覧です。 セッション履歴は、コマンドの実行順序、状態、開始時刻と終了時刻を表します。 各コマンドを入力すると、PowerShell によって履歴に追加され、再利用できるようになります。 コマンド履歴の詳細については、「 about_History」を参照してください。
  • Windows PowerShell 3.0 以降では、ユーザー設定変数の$MaximumHistoryCount既定値は 4096 です。 Windows PowerShell 2.0 では、既定値は 64 です。 変数の $MaximumHistoryCount 詳細については、「 about_Preference_Variables」を参照してください。