我有一个这样的 csv 文件:
userid;memberof
user1;groupid1
user2;groupid3
user1;groupid7
user2;groupid8
我想创建一个像这样的 csv 文件:
user1;groupid1|groupid7
user2;groupid3|groupid8
我在这个论坛上看到这可以用哈希表来完成,但我无法成功。
我不得不说我是powershell的新手,所以请原谅这个问题。
我有一个这样的 csv 文件:
userid;memberof
user1;groupid1
user2;groupid3
user1;groupid7
user2;groupid8
我想创建一个像这样的 csv 文件:
user1;groupid1|groupid7
user2;groupid3|groupid8
我在这个论坛上看到这可以用哈希表来完成,但我无法成功。
我不得不说我是powershell的新手,所以请原谅这个问题。
不需要借口,这是一个非常棘手的;)
Import-CSV YourFile.txt -Delim ";" | Group-Object userid |
Select-Object @{ name="UserId"
expr={$_.Name}},
@{ name="MemberOf"
expr={($_.Group |% { $_.memberof }) -join "|" }} |
Export-CSV YourNewFile.txt -Delim ";" -NoTypeInformation
请注意,这将包括标题行“UserId;MemberOf”,因此如果您真的不想要它,那么您应该安排将其砍掉。
使用 ConvertTo-CSV 代替 Export-CSV,将其分配给变量,然后将其写出如下内容:
$output = ... |
ConvertTo-CSV -Delim ";" -NoTypeInformation
Set-Content YourNewFile.txt $output[1..($output.count)]
$original = Import-Csv .\a.csv -Delimiter ';'
$expression = {[string]::Join('|', ($_.Group | Select -expand memberof))}
$original | Group-Object userid | Select-Object @{n="userid";e={$_.Name}}, @{n="memberof";e=$expression} | Export-Csv ./b.csv -NoTypeInformation -Delimiter ';'