gpt4 book ai didi

.net - 深度复制PSObject

转载 作者:行者123 更新时间:2023-12-05 00:01:27 24 4
gpt4 key购买 nike

我有一个Powershell脚本,在其中执行以下操作

$somePSObjectHashtables = New-Object Hashtable[] $somePSObject.Length;
$somePSObjects = Import-CSV $csvPath
0..($somePSObject.Length - 1) | ForEach-Object {
$i = $_;
$somePSObjectHashtables[$i] = @{};
$somePSObject[$_].PSObject.Properties | ForEach-Object {
$somePSObjectHashtables[$i][$_.Name] = $_.Value;
}
}

我需要这样做,因为我想在CSV中制作数据的多个不同副本以执行多个不同的操作。从某种意义上说,我正在对生成的 PSObject数组执行“INNER JOIN”。我可以轻松地用 ForEach-Object遍历 $somePSObjectHashtables并在数组的每个成员上调用 Hashtable.Clone()。然后,我可以使用 New-Object PSObject -Property $someHashTable[$i]获得PSObject的深拷贝。

我的问题是,没有中间的Hashtable,有没有更简单的方法来制作深拷贝?

最佳答案

为了获得真正的深拷贝,我们可以使用二进制序列化(假设所有数据都是可序列化的;对于来自CSV的数据,绝对是这种情况):

# Get original data
$data = Import-Csv ...

# Serialize and Deserialize data using BinaryFormatter
$ms = New-Object System.IO.MemoryStream
$bf = New-Object System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
$bf.Serialize($ms, $data)
$ms.Position = 0
$data2 = $bf.Deserialize($ms)
$ms.Close()

# Use deep copied data
$data2

关于.net - 深度复制PSObject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9204829/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com