如何从数组向PowerShell对象添加属性

时间:2015-01-08 17:54:45

标签: object powershell properties powershell-ise

我有一个属性名称和值的二维数组,我需要将其添加到PowerShell对象。

使用New-ObjectAdd-Member创建和显示此类对象时,我没有任何问题:

$obj = New-Object PSObject
$obj | Add-Member NoteProperty IName($fiel.IName)
$obj | Add-Member NoteProperty SName($fiel.SName)
$obj | Add-Member NoteProperty Taggy($fiel.Taggy)
$obj | Add-Member NoteProperty Title($fiel.Title)

Write-Output $obj

Enter image description here

但是当我尝试这样的事情时:

for ($k=0; $k -lt $fieldsArray.Count; $k++)
{
    $itemobj | Add-Member –MemberType NoteProperty –Name $fieldsArray[$k].InternalName –Value $itemki[$j][$fieldsArray[$k].InternalName]
    #Write-Host $k
    #Write-Host $fieldsArray[$k].InternalName.ToString()
    #Write-Host $itemki[$j][$fieldsArray[$k].InternalName]
}

Write-Output $itemobj

Write-Output $ itemobj将只返回一个应该添加的属性成员而没有任何整齐的列名。
添加了注释掉的部分用于测试目的,并返回所有项目的正确值。

我也试过

$itemobj | Add-Member NoteProperty $fieldsArray[$k].InternalName.ToString()($fieldsArray[$k].InternalName)

没有任何改进。

为什么没有添加其他属性成员?

我有我需要的数据。如果我写:

for ($k=0; $k -lt $fieldsArray.Count; $k++)
{
    Write-Host $k
    Write-Host $fieldsArray[$k].InternalName.ToString()
    Write-Host $itemki[$j][$fieldsArray[$k].InternalName]
}

我明白了:

  

0 ID 1
   1 ContentTypeId 0x0108007345CD807822EA4E85691E5C642F3A27
   2 ContentType
   3 标题任务0    4 修改2014年11月24日下午12:29:30

这些正是我期望和想要的价值观。问题是将它们作为属性添加到对象。我认为我不能将变量设为NotePropertyName,但根据我得到的结果,这是一个疯狂的猜测。

$ itemki [$ j] [$ fieldsArray [$ k] .InternalName]中的某些值为空 - 可能是吗?

忘记所有数组。他们只是为了上下文:

Write-Host $fieldsArray[$k].InternalName.ToString() # Writes out the correct value
Write-Host $itemki[$j][$fieldsArray[$k].InternalName] # writes out the correct value
$itemobj | Add-Member NoteProperty $fieldsArray[$k].InternalName.ToString()($fieldsArray[$k].InternalName) # The values/property are not added

问题是:为什么不呢? Add-Member在将值作为变量传递时是否有任何限制?空值?

3 个答案:

答案 0 :(得分:10)

我仍然不确定,但如果您只关注Add-Member,请考虑以下事项。

$fieldsarray = "ID", "ContentTypeID", "ContentType", "Title", "Modified"
$itemki = "1", "0x0108007345CD807822EA4E85691E5C642F3A27", "", "Task0", "11/24/2014 12:29:30 PM"
$itemobj = New-Object pscustomobject
for($k=0;$k -lt $fieldsArray.Count ; $k++)
{
    $itemobj | Add-Member NoteProperty $fieldsarray[$k] $itemki[$k]
}

$itemobj

注意数组$itemki中的空字符串条目。这将生成输出。

ID            : 1
ContentTypeID : 0x0108007345CD807822EA4E85691E5C642F3A27
ContentType   :
Title         : Task0
Modified      : 11/24/2014 12:29:30 PM

""更改为空元素:"1","0x0108007345CD807822EA4E85691E5C642F3A27",,"Task0","11/24/2014 12:29:30 PM",即可获得此输出:

ID            : 1
ContentTypeID : 0x0108007345CD807822EA4E85691E5C642F3A27
ContentType   : {Task0}
Title         : 11/24/2014 12:29:30 PM
Modified      :

哪个错了。然后,如果将空元素更改为$null,则输出看起来与第一个类似:

ID            : 1
ContentTypeID : 0x0108007345CD807822EA4E85691E5C642F3A27
ContentType   :
Title         : Task0
Modified      : 11/24/2014 12:29:30 PM

关于您的输出

你说当你在循环之外$itemobj时,你只能获得最后一个元素。每次通过后$itemobj看起来像什么? for(;;){}循环不会以ForEach-Object{}值得一提的方式将数据发送到输出流。

答案 1 :(得分:2)

不要执行For循环,执行ForEach-Object循环。类似的东西:

$Object = New-Object PSObject
$Array | ForEach{
    Add-Member -InputObject $Object -NotePropertyName $_[0] -NotePropertyValue $_[1]
}

我认为应该做你正在寻找的事情。

答案 2 :(得分:2)

您可以使用哈希表而不是两个数组。从哈希表创建对象非常容易。这是一个例子:

$hash = @{
    ID            = '1'
    ContentTypeID = '0x0108007345CD807822EA4E85691E5C642F3A27'
    ContentType   = ''
    Title         = 'Task0'
    Modified      = '11/24/2014 12:29:30 PM'
}

$Object = New-Object PSObject -Property $hash