[英]How to create 2 loops?
我有一个带有NetworkID和NewFileName字段的csv文件。 我在文件共享上有一堆文件。 以domain_networkid_Lthumb.jpg命名的文件共享下的文件名。
这个想法是从csv的每一行读取的,然后使用contains(我猜)找到文件。 如果找到至少包含networkid_lthumb的文件,则将此文件重命名为NewFileName.jpg。
做这个的最好方式是什么? 我有以下代码。 我只是想提高效率。
# Renames file based on CSV
$csvFile = Import-csv 'c:\userdata.csv'
$files = Get-ChildItem "c:\eePics\"
foreach($user in $csvFile)
{
$account = $user.networkid
$keyword = $account + "_LThumb"
$file = Get-Content $files.FullName
$ContainsWord = $file | %{$_ -match $keyword}
if($ContainsWord -contains $true)
{
Rename-Item $_.name -NewName $user.NewFileName
}
}
如果我正确理解了您要实现的目标,则应正常工作:
$csvFile = Import-csv "C:\userdata.csv"
$filePath = "C:\eepics\"
$destination = "C:\example\folder\"
foreach($user in $csvFile){
$filename = $user.networkid + "_LThumb"
Get-Childitem $filePath | where {$_.Name -match $filename} | Rename-Item -NewName $user.NewFileName
Copy-Item $filePath$($user.NewFileName) -Destination $destination
}
请注意,csv中的NewFileName必须包含文件扩展名(例如“ .jpg”)
-contains
用于测试集合(例如数组)是否包含值。 布尔比较,例如您要在if语句中尝试执行的比较,如下所示:
if($variable){}
如果$variable
为True,则将执行该块
关于您的代码:
$file = Get-Content $files.FullName
实际上将获取目录C:\\ eepics \\中所有文件的内容(如果我说是内容,我是说真的)
$ContainsWord = $file | %{$_ -match $keyword}
将逐行循环浏览所有文件的所有内容,并查看是否有匹配$ keyword的文件
更新:由于用户请求,添加了重命名后复制文件的代码
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.