【发布时间】:2023-03-22 03:40:01
【问题描述】:
我有一个变量$metrics,由于缺乏确定性,我将其称为数组数组?我可能错了,但这是我能想到的最好的。
这是变量。
PS C:\Windows\system32> $metrics
Id : cpuUtil01
Label : CPUUtilization
Messages : {}
StatusCode : Complete
Timestamps : {11/27/2021 7:00:00 PM, 11/27/2021 7:05:00 PM, 11/27/2021 7:10:00 PM, 11/27/2021 7:15:00 PM...}
Values : {51.22, 31.3833333333333, 31.4116666666667, 31.5283333333333...}
我想将$metrics.timestamps 和$metrics.values 提取出来,以便将它们导出到CSV 文件中,这样我就可以使用Excel 的折线图。我不知道如何将它们两个提取到一个变量中。
我可以一次做一个,如下所示,但是我如何加入他们以便我有一个可以使用的 CSV。
$o = ""
$out = @()
foreach ($GetMetric in $Metrics.timestamps){
$o = New-Object -TypeName PSCustomObject -Property ([ordered]@{
TimeStampUTC = $GetMetric;
})
$out += $o
}
$out
TimeStampUTC
------------
11/27/2021 7:00:00 PM
11/27/2021 7:05:00 PM
11/27/2021 7:10:00 PM
11/27/2021 7:15:00 PM
11/27/2021 7:20:00 PM
11/27/2021 7:25:00 PM
11/27/2021 7:30:00 PM
11/27/2021 7:35:00 PM
11/27/2021 7:40:00 PM
11/27/2021 7:45:00 PM
$o = ""
$out = @()
foreach ($GetMetric in $Metrics.values){
$o = New-Object -TypeName PSCustomObject -Property ([ordered]@{
Values = $GetMetric;
})
$out += $o
}
$out
Values
------
51.22
31.3833333333333
31.4116666666667
31.5283333333333
31.4166666666667
31.425
31.4916666666667
31.4166666666667
31.325
31.5916666666667
我想要的是一个具有两个值的变量,如下所示,因此我可以将其输出到 csv 文件。
PS C:\Windows\system32> $output
TimeStampUTC Values
------------ ------
11/27/2021 7:00:00 PM 51.22
11/27/2021 7:05:00 PM 31.3833333333333
11/27/2021 7:10:00 PM 31.4116666666667
11/27/2021 7:15:00 PM 31.5283333333333
11/27/2021 7:20:00 PM 31.4166666666667
11/27/2021 7:25:00 PM 31.425
11/27/2021 7:30:00 PM 31.4916666666667
11/27/2021 7:35:00 PM 31.4166666666667
11/27/2021 7:40:00 PM 31.325
11/27/2021 7:45:00 PM 31.5916666666667
你会怎么做?
非常感谢任何帮助。
-橄榄球
这是我对 .GetType() 和 Get-Member 的输出
PS C:\Windows\system32> $metrics.GeTtype()
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True True List`1 System.Object
PS C:\Windows\system32> $metrics.Values.GetType()
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True True Object[] System.Array
PS C:\Windows\system32> $metrics | Get-Member
TypeName: Amazon.CloudWatch.Model.MetricDataResult
Name MemberType Definition
---- ---------- ----------
Equals Method bool Equals(System.Object obj)
GetHashCode Method int GetHashCode()
GetType Method type GetType()
ToString Method string ToString()
Id Property string Id {get;set;}
Label Property string Label {get;set;}
Messages Property System.Collections.Generic.List[Amazon.CloudWatch.Model.MessageData] Messages {get;set;}
StatusCode Property Amazon.CloudWatch.StatusCode StatusCode {get;set;}
Timestamps Property System.Collections.Generic.List[datetime] Timestamps {get;set;}
Values Property System.Collections.Generic.List[double] Values {get;set;}
【问题讨论】:
标签: arrays powershell variables hashtable