次の方法で共有


ConvertFrom-Csv

文字区切り値 (CSV) 形式のオブジェクト プロパティを元のオブジェクトの CSV バージョンに変換します。

構文

ConvertFrom-Csv
                [[-Delimiter] <Char>]
                [-InputObject] <PSObject[]>
                [-Header <String[]>]
                [<CommonParameters>]
ConvertFrom-Csv
                -UseCulture
                [-InputObject] <PSObject[]>
                [-Header <String[]>]
                [<CommonParameters>]

説明

このコマンドレットは ConvertFrom-Csv 、CSV データの各行について、文字区切り値 (CSV) データを PSObject 型オブジェクトに変換します。 新しいオブジェクトは、CSV データから読み取られた順序でパイプラインに書き込まれます。 CSV の列ヘッダー行の値は、新しい 各 PSObject に追加されるプロパティの名前になります。

作成する ConvertFrom-Csv オブジェクトは、 CSV ファイル内の各行の PSObject 型オブジェクトです。 CSV オブジェクトのプロパティ値は、元のオブジェクトのプロパティ値の文字列バージョンです。 CSV バージョンのオブジェクトにはメソッドがありません。

また、and Import-Csv コマンドレットをExport-Csv使用して、オブジェクトをファイル内の CSV 文字列に変換して戻すこともできます。 これらのコマンドレットは、CSV 文字列をファイルに ConvertTo-Csv 保存する点を除き、コマンドレットと ConvertFrom-Csv 同じです。

PSObject 型メイン列ヘッダーの順序でプロパティの順序が格納されます。 これは、オブジェクトを CSV 形式に変換するときに同じ列の順序を取得することを意味します。

例 1: ローカル コンピューター上のプロセスを CSV 形式に変換する

この例では、ローカル コンピューター上のプロセスを CSV 形式に変換し、オブジェクト形式に復元する方法を示します。

$P = Get-Process | ConvertTo-Csv
$P | ConvertFrom-Csv

このコマンドレットは Get-Process 、プロセスをパイプラインの下に送信します ConvertTo-Csv。 このコマンドレットは ConvertTo-Csv 、プロセス オブジェクトを一連の CSV 文字列に変換します。 このコマンドレットは ConvertFrom-Csv 、CSV 文字列を元のプロセス オブジェクトの CSV バージョンに変換します。 CSV 文字列は変数に $P 保存されます。

例 2: データ オブジェクトを CSV 形式に変換し、次に CSV オブジェクト形式に変換する

この例では、データ オブジェクトを CSV 形式に変換してから、CSV オブジェクト形式に変換する方法を示します。

$Date = Get-Date | ConvertTo-Csv -Delimiter ';'
ConvertFrom-Csv -InputObject $Date -Delimiter ';'

最初のコマンドは、パイプラインConvertTo-Csvの現在の日付と時刻を送信するために使用Get-Dateします。 コマンドレットは ConvertTo-Csv 、日付オブジェクトを一連の CSV 文字列に変換します。 Delimiter パラメーターは、セミコロン区切り記号を指定するために使用されます。 文字列は変数に $Date 保存されます。

例 3: ヘッダー パラメーターを使用してプロパティの名前を変更する

この例では、Header パラメーターConvertFrom-Csv使用して、結果としてインポートされたオブジェクトのプロパティの名前を変更する方法を示します。

$J = Start-Job -ScriptBlock { Get-Process } | ConvertTo-Csv  -NoTypeInformation
$Header = 'State', 'MoreData', 'StatusMessage', 'Location', 'Command',
          'StateInfo', 'Finished', 'InstanceId', 'Id', 'Name', 'ChildJobs',
          'BeginTime', 'EndTime', 'JobType', 'Output', 'Error', 'Progress',
          'Verbose', 'Debug', 'Warning', 'Information'
# Delete the default header from $J
$J = $J[1..($J.count - 1)]
$J | ConvertFrom-Csv -Header $Header

State         : Running
MoreData      : True
StatusMessage :
Location      : localhost
Command       : Get-Process
StateInfo     : Running
Finished      : System.Threading.ManualResetEvent
InstanceId    : a259eb63-6824-4b97-a033-305108ae1c2e
Id            : 1
Name          : Job1
ChildJobs     : System.Collections.Generic.List`1[System.Management.Automation.Job]
BeginTime     : 12/20/2018 18:59:57
EndTime       :
JobType       : BackgroundJob
Output        : System.Management.Automation.PSDataCollection`1[System.Management.Automation.PSObject]
Error         : System.Management.Automation.PSDataCollection`1[System.Management.Automation.ErrorRecord]
Progress      : System.Management.Automation.PSDataCollection`1[System.Management.Automation.ProgressRecord]
Verbose       : System.Management.Automation.PSDataCollection`1[System.Management.Automation.VerboseRecord]
Debug         : System.Management.Automation.PSDataCollection`1[System.Management.Automation.DebugRecord]
Warning       : System.Management.Automation.PSDataCollection`1[System.Management.Automation.WarningRecord]
Information   : System.Management.Automation.PSDataCollection`1[System.Management.Automation.InformationRecord]

コマンドレットは Start-Job 、実行 Get-Processするバックグラウンド ジョブを開始します。 ジョブ オブジェクトはパイプライン ConvertTo-Csv に送信され、CSV 文字列に変換されます。 NoTypeInformation パラメーターは、CSV 出力から型情報ヘッダーを削除し、PowerShell v6 以降では省略可能です。 この$Header変数には、HasMoreData、JobStateInfo、PSBeginTimeP Standard Edition ndTime、PSJobTypeName の既定値を置き換えるカスタム ヘッダーが含まれています。 変数には $J CSV 文字列が含まれており、既定のヘッダーを削除するために使用されます。 このコマンドレットはConvertFrom-Csv、CSV 文字列を PSCustomObject に変換し、Header パラメーターを使用して変数を$Header適用します。

例 4: サービス オブジェクトの CSV 文字列を変換する

この例では、UseCulture パラメーターでコマンドレットをConvertFrom-Csv使用する方法を示します。

(Get-Culture).TextInfo.ListSeparator
$Services = (Get-Service | ConvertTo-Csv)
ConvertFrom-Csv -InputObject $Services -UseCulture

このコマンドレットは Get-Culture 、入れ子になったプロパティ TextInfoListSeparator を使用して、現在のカルチャの既定のリスト区切り記号を取得します。 このコマンドレットは Get-Service 、サービス オブジェクトをパイプラインの下に送信します ConvertTo-Csv。 サービス ConvertTo-Csv オブジェクトを一連の CSV 文字列に変換します。 CSV 文字列は変数に $Services 格納されます。 コマンドレットは ConvertFrom-Csv InputObject パラメーターを使用し、変数から CSV 文字列を$Services変換します。 UseCulture パラメーターは、現在のカルチャの既定のリスト区切り記号を使用します。

UseCulture パラメーターを使用する場合は、現在のカルチャの既定のリスト区切り記号が、CSV 文字列で使用されている区切り記号と一致していることを確認してください。 それ以外の場合は、 ConvertFrom-Csv CSV 文字列からオブジェクトを生成できません。

パラメーター

-Delimiter

CSV 文字列内のプロパティ値を区切る区切り記号を指定します。 既定値はコンマ (,) です。 コロン (:) などの文字を入力します。 セミコロン (;) を指定するには、単一引用符で囲みます。

ファイルに実際の文字列区切り記号以外の文字を指定した場合、 ConvertFrom-Csv CSV 文字列からオブジェクトを作成して CSV 文字列を返すことはできません。

型:Char
配置:1
規定値:comma (,)
必須:False
パイプライン入力を受け取る:False
ワイルドカード文字を受け取る:False

-Header

インポートされた文字列の代替列ヘッダー行を指定します。 列ヘッダーは、によって ConvertFrom-Csv作成されるオブジェクトのプロパティ名を決定します。

列ヘッダーを文字区切りリストとして入力します。 ヘッダー文字列を引用符で囲まないでください。 各列ヘッダーを単一引用符で囲みます。

データ列よりも少ない列ヘッダーを入力すると、再メインデータ列はカード解除されます。 データ列よりも多くの列ヘッダーを入力すると、空のデータ列で追加の列ヘッダーが作成されます。

Header パラメーターを使用する場合は、CSV 文字列から列ヘッダー文字列を省略します。 それ以外の場合、このコマンドレットはヘッダー行の項目から追加のオブジェクトを作成します。

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

-InputObject

オブジェクトに変換する CSV 文字列を指定します。 CSV 文字列が格納されている変数を入力するか、CSV 文字列を取得するコマンドまたは式を入力します。 CSV 文字列 ConvertFrom-Csvをパイプ処理することもできます。

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

-UseCulture

現在のカルチャのリスト区切り記号を項目区切り記号として使用します。 カルチャのリスト区切り記号を検索するには、次のコマンドを使用します (Get-Culture).TextInfo.ListSeparator

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

入力

String

CSV 文字列をこのコマンドレットにパイプできます。

出力

PSObject

このコマンドレットは、CSV 文字列のプロパティによって記述されたオブジェクトを返します。

メモ

CSV 形式では、各オブジェクトは、オブジェクトのプロパティ値の文字区切りのリストで表されます。 プロパティ値は、オブジェクトのメソッドを使用して文字列に ToString() 変換されます。 オブジェクトのメソッドをエクスポートする方法はありません。