Renomear arquivos em lote e movê-los para subpastas (que devem ser criadas)

Renomear arquivos em lote e movê-los para subpastas (que devem ser criadas)

Eu tenho uma pasta cheia de arquivos no formato "10389-2001.pdf", então primeiro um número de cinco dígitos, um hífen e depois um número de quatro dígitos. Quero renomear tudo para que o arquivo em si seja chamado apenas de "2001.pdf", mas seja movido para uma nova subpasta "10389". Como esta subpasta ainda não existe, ela precisará ser criada.

Estou aberto a sugestões de como fazer isso na linha de comando do Windows, no Powershell ou no Cygwin.

Responder1

Um script do PowerShell:

Get-ChildItem *-*.pdf|Foreach-object {
    $Dir, $File = $_.Name.Split('-')[0,1]
    if (!(Test-Path $Dir)){MD $Dir}
    $_| Move -Destination ("$Dir\$File") 
}

O lote:

@echo off
for /F "Tokens=1* delims=-" %%A in ('Dir /B "*-*.pdf"') do (
    If not exist ".\%%A" MD ".\%%A"
    Move "%%A-%%B" "%%A\%%B"
)

Árvore antes:

> tree /f .
Z:\
    10389-2001.pdf
    10815-2017.pdf

Árvore depois:

> tree /f .
Z:\
├───10389
│       2001.pdf
└───10815
        2017.pdf

Responder2

Fácil com VBS. Copie o código para um arquivo com extensão '.vbs'

on Error Resume Next   
sFolder = "D:\test\"
dFolder = "D:\test1\"
Set oFSO = CreateObject("Scripting.FileSystemObject")

For Each oFile In oFSO.GetFolder(sFolder).Files
    NameParts = split(oFile.Name,"-")
    Set f = oFSO.CreateFolder(dFolder & NameParts(0))
    set fi = oFSO.GetFile(oFile)
    fi.Copy dFolder & NameParts(0) & "\" & NameParts(1)
Next

ajuste a pasta de origem e destino. Não esqueça "\" no final. A pasta de destino deve existir. Codificado rápido e sujo. Apenas ?????-????? arquivos em sourceFolder.

informação relacionada