首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从哈希表替换CSV中的文本

从哈希表替换CSV中的文本
EN

Stack Overflow用户
提问于 2017-10-16 07:22:43
回答 2查看 205关注 0票数 0

我正在尝试Import-Csv "Newusers.csv",这是一个从工资系统导出。我需要将其导入Active Directory,并需要为每个用户更新CSV文件中的physicalDeliveryOfficeName列。

目前,从工资单系统导出用户的站点名称的代码。我需要将此代码替换为站点名称。我有一个哈希表,其中包含site code = site name。我有超过100个地点。

代码语言:javascript
运行
复制
$hashtable = @{
    28 = 'Example Site 1'
    29 = 'Example Site 2'
    36 = 'Example Site 3'
    37 = 'Example Site 4'
    50 = 'Example Site 5'
    51 = 'Example Site 6'
    52 = 'Example Site 7'
    53 = 'Example Site 8'
}
EN

回答 2

Stack Overflow用户

发布于 2017-10-16 07:28:33

i有100多个站点

在这种情况下,您肯定是在正确的道路上。

访问哈希表时,使用站点代码值作为关键字:

代码语言:javascript
运行
复制
Import-Csv newusers.csv |ForEach-Object {
    Set-ADUser -Identity $_.username -replace @{physicalDeliveryOffice=$hashtable[$_.sitecode]}
}
票数 2
EN

Stack Overflow用户

发布于 2017-10-16 16:24:30

要将CSV中的站点代码替换为站点名称,请导入CSV,修改列,然后将数据导出回CSV。有几种方法可以解决此问题,例如,使用calculated property替换使用Select-Object的整个列

代码语言:javascript
运行
复制
$file = 'C:\path\to\newusers.csv'
(Import-Csv $file) |
    Select-Object *,@{n='SiteName';e={$hashtable[$_.sitecode]}} -Exclude sitecode |
    Export-Csv $file -NoType

或者只需在循环中更改列中的值:

代码语言:javascript
运行
复制
$file = 'C:\path\to\newusers.csv'
$csv  = Import-Csv $file
foreach ($record in $csv) {
    $record.sitecode = $hashtable[$_.sitecode]
}
$csv | Export-Csv $file -NoType
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46760995

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档