powershell - 使用 PowerShell 加入对象两个不同的 csv 文件
问题描述
第一个 .csv 文件是基于客户端名称的每月备份大小(以 KB 为单位)。第二个 .csv 文件是基于客户端名称的以 KB 为单位的下个月备份大小。
它在 A 列中列出了所有客户端名称。B 列具有客户端的相应策略名称和以 KB 为单位的最后一列备份大小(即 - 487402463)。
如果客户端大小(1638838488 - 1238838488 = 0.37 in TB)之间的差异大于 0.10 TB,则结果将以 TB 大小输出到如下所示的 csv 文件中。
此外,一个客户端可能关联多个策略名称。
我的问题是:我也想添加一些东西。
- 下个月的备份大小可能会减少,例如 hostname15、Company_Policy_11。
- 此外,hostname55,Company_Policy_XXX 可能有不同的策略名称。
- hostnameXX,Company_Policy_XXX,0 和 hostnameXX,Company_Policy_XXX,41806794 它可能是重复的客户端和策略名称。如果这在 CSV2 中不存在,那么我想显示为负数(-0.14),如下所示。或者也可能存在于 CSV2 主机名 ZZ、Company_Policy_XXX 中。
- 最后,它可能在 CSV2 中,例如 hostnameSS、Company_Policy_XXX。我使用了 Join-Object 模块。https://github.com/ili101/Join-Object
示例 CSVFile1.csv
Client Name,Policy Name,KB Size
hostname1,Company_Policy,487402463
hostname2,Company_Policy,227850336
hostname3,Company_Policy_11,8360960
hostname4,Company_Policy_11,1238838488
hostname15,Company_Policy_11,3238838488
hostname1,Company_Policy_55,521423110
hostname10,Company_Policy,28508975
hostname3,Company_Policy_66,295925
hostname5,Company_Policy_22,82001824
hostname2,Company_Policy_33,26176885
hostnameXX,Company_Policy_XXX,0
hostnameXX,Company_Policy_XXX,141806794
hostnameYY,Company_Policy_XXX,121806794
hostname55,Company_Policy_XXX,41806794
hostnameZZ,Company_Policy_XXX,0
hostnameZZ,Company_Policy_XXX,141806794
示例 CSVFile2.csv
Client Name,Policy Name,KB Size
hostname1,Company_Policy,487402555
hostname2,Company_Policy,227850666
hostname3,Company_Policy_11,8361200
hostname4,Company_Policy_11,1638838488
hostname1,Company_Policy_55,621423110
hostname15,Company_Policy_11,1238838488
hostname10,Company_Policy,28908975
hostname3,Company_Policy_66,295928
hostname5,Company_Policy_22,92001824
hostname2,Company_Policy_33,36176885
hostname22,Company_Policy,291768854
hostname23,Company_Policy,291768854
hostname55,Company_Policy_BBB,191806794
hostnameZZ,Company_Policy_XXX,0
hostnameZZ,Company_Policy_XXX,291806794
hostnameSS,Company_Policy_XXX,0
hostnameSS,Company_Policy_XXX,291806794
期望的输出:
Client Name,Policy Name,TB Size
hostname4,Company_Policy_11,0.37
hostname22,Company_Policy,0.27
hostname23,Company_Policy,0.27
hostnameYY,Company_Policy_XXX,-0.12
hostnameXX,Company_Policy_XXX,-0.14
hostname15,Company_Policy_11,-2
hostname55,Company_Policy_BBB,0.15
hostnameZZ,Company_Policy_XXX,0.15
hostnameSS,Company_Policy_XXX,0.29
到目前为止,这是我的脚本:
$CSV2 | FullJoin $CSV1 `
-On 'Client Name','Policy Name' `
-Property 'Client Name',
'Policy Name',
@{'TB Size' = {[math]::Round(($Left.'KB Size' - $Right.'KB Size') * 1KB / 1TB, 2)}} |
Where-Object {[math]::Abs($_.'TB Size') -gt 0.10} | Export-Csv C:\Toolbox\DataReport.csv -NoTypeInformation
解决方案
您可以这样做类似于以下内容。这假设您要从 CSV2 值中减去 CSV1 值。
# Read CSV files and make CSV1 sizes negative. Makes summing totals simpler.
$1 = Import-Csv CSVFile1.csv | Foreach-Object { $_.'KB Size' = -$_.'KB Size'; $_ }
$2 = Import-Csv CSVFile2.csv
# Calculated Properties to be used with Select-Object
$CalculatedProperties = @{n='Client Name';e={$_.Group.'Client Name' | Get-Unique}},
@{n='Policy Name';e={$_.Group.'Policy Name' | Get-Unique}},
@{n='TB Size';e={[math]::Round(($_.Group.'KB Size' | Measure -Sum).Sum*1KB/1TB,2)}}
# Grouping objects based on unique client and policy name combinations
$1 + $2 | Group-Object 'Client Name','Policy Name' |
Select-object $CalculatedProperties |
Where {[math]::Abs($_.'TB Size') -gt 0.10}
推荐阅读
- django - 在多对一关系下,pizzas.html 上不显示比萨饼的名称 [Python 速成课程练习 18-8]
- c# - 我正在模拟请求但它显示为空?
- xslt - 如何中断页面序列以插入另一个页面序列
- rabbitmq - 队列镜像中未自动选择新主节点
- javascript - setState 没有设置状态,在 componentDidUpdate 中的获取请求后它没有按预期工作?
- c# - C# Win form Selenium 挂起
- cucumber - Cucumber Java8:为什么我会得到“PendingException:TODO:实现我”?
- d3.js - 如何对从外部数据生成的 d3 元素进行分组?
- reactjs - keyboardAvoidingView 在 react-native 中不起作用
- r - 在dataframe / data.table中,在特定条件下将组内的变量设置为上一列中的值