在文件中查找文本,然后批量重命名文件

在文件中查找文本,然后批量重命名文件

我在创建脚本时遇到了一些问题,该脚本在文件夹内的每个文件中找到特定的文本,获取该文本后的内容并将其设置为文件的名称,所有这些都在循环内,对多个文件执行相同的操作。

例如,我有一个文件夹,其中包含 file1、file2、file3

content in file1: sw_part = "ABC-DEF.GHJ";
content in file2: sw_part = "ABC-123.XYZ";
content in file3: sw_part = "ABCDE-FGHJ.KLMN";

结果应该是:

file1 renamed to ABC-DEF.GHJ
file2 renamed to ABC-123.XYZ
file3 renamed to ABCDE-FGHJ.KLMN

我做的是这样的:

for /F "tokens=2 delims==" %%a in ('findstr /I "sw_part" file1') do set "swpart=%%a"  
echo sw part is: %swpart%   
copy file1 "%swpart%"

这工作正常,但它只适用于给定的文件(我不能让它循环工作)并且它重命名文件;最后。有什么帮助吗?

它需要以批处理方式完成。PowerShell 也可以。

谢谢

答案1

下面的脚本将执行您想要的操作。

cd C:\temp\swpart

$files = [System.Collections.ArrayList]@()

select-string -Path "*.*" -Pattern "sw_part" | ForEach-Object {
   
    $old_filename = $_.Filename

    $new_filename = $_.line -replace "^.*sw_part = ""","" -replace """.*$",""


    # put everything in array, so the files get closed and can be renamed later.
    $null = $files.Add(@{"old"=$old_filename;"new"=$new_filename})

}

$files |ForEach-Object{
    $old_filename = $_.old
    $new_filename = $_.new

    rename-item $old_filename $new_filename -Force
}


确保改变第一行以更改为文件所在的路径。

如果由于某种原因并非所有文件都重命名,请再次运行脚本。然后该文件仍在使用中。

答案2

  • 使用 PowerShell,您也可以仅使用两行来完成此操作:
ls 'F:\2020-SU\Q1605996\*.txt'|%{$new=(cat $_.FullName).split('\"*\"')[-2];ren $_.FullName -new $new -force}
  • 不使用别名:
Get-ChildItem 'F:\2020-SU\Q1605996\*.txt' | ForEach {
      $new=(Get-Content $_.FullName).split('\"*\"')[-2]
      Rename-Item $_.FullName -new $new -force
     }


  • 您也可以使用 cmd 在一行中执行此操作:

在命令行中:

for /f tokens^=1-3delims^=^:^"^" %a in ('findstr . *.txt')do @ren "%~fa" "%~c"

在 bat/cmd 文件中:

@echo off 

cd /d "C:\Path\To\Your\Folder"
for /f tokens^=1-3delims^=:^"^" %%a in ('findstr . *.txt')do @ren "%%~fa" "%%~c"

Findstr命令和输出

>F:\Q1605996>findstr . *.txt
file1.txt:sw_part = "ABC-DEF.GHJ";
file2.txt:sw_part = "ABC-123.XYZ";
file3.txt:sw_part = "ABCDE-FGHJ.KLMN";
file4.txt:sw_part = "ABCDE-FGHJ.KXMN";more test/strings
file5.txt:this is a test; sw_part = "fea.geow.eaf.gae"; this is another test;

For循环命令机制

set yours delimiters : + " + "   ==>>    delims^=:^"^" 
set yours tokens "1" - "3"             ==>>    tokens^=1-3
              :        =                  ;
     token = 1:token =2=         token = 3;
     file1.txt:sw_part = "ABC-DEF.GHJ"    ;
     file2.txt:sw_part = "ABC-123.XYZ"    ;
     file3.txt:sw_part = "ABCDE-FGHJ.KLMN";
     file4.txt:sw_part = "ABCDE-FGHJ.KXMN";more test/strings
    |         |          |               |
ren    "%f~a"                  "%~c"
ren "F:\Q1605996\file1.txt"  "ABC-DEF.GHJ"
ren "F:\Q1605996\file2.txt"  "ABC-123.XYZ"
ren "F:\Q1605996\file3.txt"  "ABCDE-FGHJ.KLMN"
ren "F:\Q1605996\file4.txt"  "ABCDE-FGHJ.KXMN"


rem :: The same in file5.txt 
     file5.txt:this is a test;sw_part = "fea.geow.eaf.gae"; this is another test;
    |         |                         |                |
ren    "%f~a"                                 "%~c"
ren "F:\Q1605996\file5.txt"             "fea.geow.eaf.gae"



PowerShell 的其他资源:

附加资源cmd/batch:

相关内容