Get-History

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

構文

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

説明

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

PowerShell では、各セッションの履歴が自動的にメインされます。 セッション履歴のエントリ数は、基本設定変数の $MaximumHistoryCount 値によって決まります。 Windows PowerShell 3.0 以降では、既定値は 4096. 既定では、履歴ファイルはホーム ディレクトリに保存されますが、任意の場所にファイルを保存することができます。 PowerShell の履歴機能の詳細については、「about_History」を参照してください

セッション履歴は、PSReadLine モジュールメイン含まれる履歴とは別に管理されます。 両方の履歴は、PSReadLine読み込まれるセッションで使用できます。 このコマンドレットは、セッション履歴でのみ機能します。 詳細については、 about_PSReadLineを参照してください。

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

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

Get-History

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

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

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

例 3: 履歴エントリを特定の ID までエクスポートする

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

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

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

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

Get-History -Count 1

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

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

Get-History | Format-List -Property *

パラメーター

-Count

このコマンドレットが取得する最新の履歴エントリの数を指定します。 既定では、 Get-History セッション履歴のすべてのエントリを取得します。 コマンドで Count パラメーターと Id パラメーターの両方を使用すると、表示は 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 は、指定されたエントリのみを取得します。 コマンドで Id パラメーターと Count パラメーターの両方を使用する場合は、 Get-History Id パラメーターで指定されたエントリで終わる最新のエントリを取得します。

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

入力

Int64

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

出力

HistoryInfo

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

メモ

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

  • h
  • history
  • ghy

セッション履歴は、セッション中に入力したコマンドの一覧です。 セッション履歴は、コマンドの実行順序、状態、開始時刻と終了時刻を表します。 各コマンドを入力すると、PowerShell によって履歴に追加され、再利用できるようになります。 コマンド履歴の詳細については、about_Historyを参照してください

Windows PowerShell 3.0 以降では、基本設定変数の $MaximumHistoryCount 既定値は 4096. Windows PowerShell 2.0 では、既定値は 64. $MaximumHistoryCount 変数の詳細については、「about_Preference_Variables」を参照してください。