繁体   English   中英

从CSV获取数据以从多个服务器删除用户文件夹

[英]Get data from CSV to delete users folders from multiple servers

我对Powershell非常陌生,情况是我有一些不需要的用户文件夹,必须在其他服务器上将其删除。 所有服务器上的路径均为fe“ \\ server1 \\ hiddenshare $ \\ username”。我的CSV如下所示:

ServerName,FolderName
SERVER1,AAAA
SERVER2,AAA1
SERVER3,AAA2

我正在尝试运行以下代码:

$path = "C:\temp\servers_folders.csv"
$ServerName = Import-Csv -Path $path
$FolderName = Import-CSV -Path $path
Import-Csv -Path $path | % {
  Remove-Item -Path \\$ServerName\hiddenshare$\$FolderName -Recurse
    }

毕竟我得到这个错误:

Remove-Item : Cannot find path '\\  \$\  ' because it does not exist.
At C:\temp\servers_folders.csv.ps1:5 char:3
+   Remove-Item -Path \\$ServerName\hiddenshare$\$FolderName -Recurse
+   ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : ObjectNotFound: (\\  \usr$\  :String) [Remove-Item], ItemNotFoundException
    + FullyQualifiedErrorId : PathNotFound,Microsoft.PowerShell.Commands.RemoveItemCommand

您不需要多次导入csv。 在foreach块中,您必须通过$_引用当前项目

试试这个,删除-whatif(如果可以)

$servers=import-csv .\servers.csv

$servers | %{
    remove-item -path \\$($_.servername)\users$\$($_.FolderName) -whatif
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM