組み込みメンバーについて

簡単な説明

すべての PowerShell オブジェクトで使用できる PowerShell の組み込みメンバーに関する情報を提供します。

詳しい説明

オブジェクトが作成されると、PowerShell によって各オブジェクトにいくつかの "非表示" プロパティとメソッドが追加されます。 これらのプロパティとメソッドは、組み込みメンバーと 呼ばれます。 通常、これらの組み込みメンバーはビューから非表示になります。 これらの非表示のメンバーは、Get-MemberForce パラメーターを使用して確認できます。

オブジェクト ビュー

組み込みメンバーには、オブジェクトの ビューを表す MemberSet プロパティのセットが含まれます。 MemberSet プロパティの詳細については、「PSMemberSet」を参照してください

すべての PowerShell オブジェクトには、次のプロパティが含まれています。

  • psbase

    psbaseMemberSet には、拡張または適応のない基本オブジェクトのメンバーが含まれます。 オブジェクトの種類によっては、インスタンスによって [psobject] ラップされた .NET インスタンスか、ラッパーがない場合は入力オブジェクト自体になります。

  • psadapted

    MemberSet にはpsadapted、基本オブジェクトと適合したメンバー (存在する場合) が表示されます。 適合メンバーは拡張型システム (ETS) によって追加されます。

  • psextended

    MemberSet にはpsextendedTypes.ps1xml ファイルと Add-Member コマンドレットによって追加されたメンバーのみが表示されます。 コマンドレットを使用して、実行時に任意のオブジェクトを Add-Member 拡張できます。

  • psobject

    MemberSetpsobject、メソッド、プロパティ、およびオブジェクトに関するその他の情報を含む任意のオブジェクトのリフレクションの豊富なソースです。

この例では、 $hash ユーザーに関する情報を含むハッシュテーブルです。 Force パラメーターGet-Member、オブジェクトの組み込みメンバーを示します。

$hash = @{
    Age  = 33
    Name = 'Bob'
}

$hash | Get-Member -Force -MemberType MemberSet, CodeProperty
   TypeName: System.Collections.Hashtable

Name        MemberType   Definition
----        ----------   ----------
pstypenames CodeProperty System.Collections.ObjectModel.Collection`1[[System.String, System.Private.CoreLib, Version=7…
psadapted   MemberSet    psadapted {Item, IsReadOnly, IsFixedSize, IsSynchronized, Keys, Values, SyncRoot, Count, Add,…
psbase      MemberSet    psbase {Item, IsReadOnly, IsFixedSize, IsSynchronized, Keys, Values, SyncRoot, Count, Add, Cl…
psextended  MemberSet    psextended {}
psobject    MemberSet    psobject {Members, Properties, Methods, ImmediateBaseObject, BaseObject, TypeNames, get_Membe…

使用 psobject は使用 Get-Memberに似ていますが、柔軟性が高くなります。 たとえば、オブジェクトのプロパティとその値を列挙できます。

$hash.psobject.Properties | Select-Object Name, MemberType, Value
Name           MemberType                    Value
----           ----------                    -----
IsReadOnly       Property                    False
IsFixedSize      Property                    False
IsSynchronized   Property                    False
Keys             Property              {Age, Name}
Values           Property                {33, Bob}
SyncRoot         Property {[Age, 33], [Name, Bob]}
Count            Property                        2

これを、ハッシュテーブルを PSCustomObject に 変換して作成されたオブジェクトと比較します

$user = [pscustomobject]$hash
$user.psobject.Properties | Select-Object Name, MemberType, Value
Name   MemberType Value
----   ---------- -----
Age  NoteProperty    33
Name NoteProperty   Bob

ハッシュテーブルのキーが PSCustomObject の プロパティに変換されていることに注意してください。 新しいプロパティが MemberSet の psextended一部になりました

$user | Get-Member -Force -MemberType MemberSet, CodeProperty
   TypeName: System.Management.Automation.PSCustomObject

Name        MemberType   Definition
----        ----------   ----------
pstypenames CodeProperty System.Collections.ObjectModel.Collection`1[[System.String, System.Private.CoreLib, Version=7…
psadapted   MemberSet    psadapted {ToString, GetType, Equals, GetHashCode}
psbase      MemberSet    psbase {ToString, GetType, Equals, GetHashCode}
psextended  MemberSet    psextended {Age, Name}
psobject    MemberSet    psobject {Members, Properties, Methods, ImmediateBaseObject, BaseObject, TypeNames, get_Membe…

型情報

CodeProperty では pstypenames 継承順にオブジェクト型階層が一覧表示されます。 次に例を示します。

$file = Get-Item C:\temp\test.txt
$file.pstypenames
System.IO.FileInfo
System.IO.FileSystemInfo
System.MarshalByRefObject
System.Object

出力は、最も具体的なオブジェクト型で始まり、 System.IO.FileInfo最もジェネリック型 System.Objectまで続きます。

メソッド

PowerShell では、すべての PowerShell オブジェクトに 2 つの非表示メソッドが追加されます。 これらのメソッドは、コマンドまたはタブ補完を Get-Member -Force 使用して表示されません。

ForEach() と Where()

メソッド ForEach()Where() メソッドは、すべての PowerShell オブジェクトで使用できます。 ただし、コレクションを操作する場合に最も便利です。 これらのメソッドの使用方法の詳細については、about_Arraysを参照してください

プロパティ

Count プロパティと Length プロパティは、コレクションだけでなく、すべての PowerShell オブジェクトで使用できます。 これらは互いに似ていますが、データ型によって動作が異なる場合があります。 たとえば、文字列の 長さは 文字列内の文字数です。 Count プロパティは、オブジェクトのインスタンスの数です。

PS> $str = 'string'
PS> $str.Length
6
PS> $str.Count
1

これらのプロパティの詳細については、「about_Properties」を参照してください

配列インデックスのスカラー型

オブジェクトがインデックス付きコレクションでない場合、インデックス演算子を使用して最初の要素にアクセスすると、オブジェクト自体が返されます。 最初の要素を超えるインデックス値が返されます $null

PS> (2)[0]
2
PS> (2)[-1]
2
PS> (2)[1] -eq $null
True
PS> (2)[0,0] -eq $null
True

詳細については、「about_Operators」を参照してください

型の New() メソッド

PowerShell 5.0 以降、PowerShell は、すべての .NET 型に静的 New() メソッドを追加します。 次の例では、同じ結果が生成されます。

$expression = New-Object -TypeName regex -ArgumentList 'pattern'
$expression = [regex]::new('pattern')

このメソッドを new() 使用する方が、 New-Object.

詳細については、「about_Remote」を参照してください。