我有一个大的CSV文件,看起来像这个名为student.export.text
学生编号,姓氏,中间名,名字,学校,年级,Dob
我正在尝试构建一个每晚运行的自动化任务,以便其他软件可以正确理解CSV。
这是我的代码,但我遗漏了导致错误的内容。我是Powershell的新手,我希望得到一些建议。
任何帮助将不胜感激!
$Replacements = @{
"5" = "AE";
"7" = "ER";
"10" = "FM";
"12" = "HC";
"14" = "JH";
"18" = "LE";
#...]
}
Import-Csv .\student.export.text | ForEach-Object {
$_.Schoolid = $Replacements[$_.Schoolid]
$_
} | Export-Csv -NoTypeInformation .\new.csv
答案 0 :(得分:1)
这是一种可行的方法。
# declare hash table with School ID to School Name mapping
$schoolIdsToNames = @{
"3" = "SchoolA";
"4" = "SchoolB"
}
# import the CSV file
$csv = Import-Csv "C:\input.csv";
# for each row, replace the School ID field with the School Name
foreach($row in $csv)
{
$row.Schoolid = $schoolIdsToNames[$row.Schoolid];
}
# export the modified CSV
$csv | Export-Csv "C:\replaced.csv" -NoTypeInformation;
在第一步中,我们设置PowerShell哈希表(一种键值对列表),然后使用Import-Csv
导入CSV文件并将其存储在$csv
变量中。此cmdlet将从CSV的每一行创建一个对象,我们可以轻松地操作它。对于每一行,我们只需将Schoolid
字段替换为$schoolIdsToNames
哈希表中分配给ID键的值。最后,我们将CSV导出到另一个文件。
另一种更为PowerShell-ly的方法是这样的:
Import-Csv "C:\test\school.csv" | Select-Object *, @{ Name = "SchoolName"; Expression = { $schoolIdsToNames[$_.Schoolid] } } | Export-Csv "C:\test\replaced2.csv" -NoTypeInformation
此单行导入CSV并将其发送到管道。对于每一行,我们使用Select-Object
选择行的所有属性,并添加一个名为SchoolName
的新属性,使用与上述相同的基于哈希表的技术设置其值。最后,我们将对象列表导出为CSV。