Извлечение имени файла - Powershell

Извлечение имени файла - Powershell

У меня возникли проблемы с извлечением некоторых данных из имени файла, так как, похоже, он добавляет пробел в конец извлеченного имени, даже если я пытаюсь использовать трюк .trim(), чтобы удалить его, это не работает. Я также пробовал подсчитать длину имени файла -1, и он оставляет пробел, но вместо этого удаляет последний символ.. это очень затрудняет для меня указание пути к созданной папке, так как я добавляю пробел в путь..

Ниже приведены имена файлов, из которых я пытаюсь извлечь данные.

12 Monkeys S02E10 - Fatherland.txt
Colony S02E01 - Eleven Thirteen.txt
Prison Break S05E05 - Contingency.txt

Я пытаюсь извлечь название телешоу и создать папку в новом каталоге, а затем переместить файл в созданную папку.

Вот код, который я использую..

$TRANSFER = 'C:\Users\BRACEGIRDLE\Favorites\Desktop\TRANSFER\'
$TVSHOWS = 'C:\Users\BRACEGIRDLE\Favorites\Desktop\TV_SHOW\'
$pattern = ‘\s+\S[0-9][0-9].*’

Get-ChildItem "$TRANSFER/*.txt" |
    ForEach-Object{

        $target = $_.BaseName -split $pattern

        Write-Host $target@123

      $jon = $TVSHOWS+$target


        If( -not (test-path $jon)) 
            {
            New-Item -ItemType Directory -force -Path $jon
            }

        Copy-Item -path $_.FullName -Destination $jon
        }

И вот ошибка

Quantico @123
Copy-Item : Could not find a part of the path 
'C:\Users\BRACEGIRDLE\Favorites\Desktop\TV_SHOW\Quantico \Quantico S02E10 - 
JMPALM.txt'.
At line:20 char:9
+         Copy-Item -path $_.FullName -Destination $jon
+         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : NotSpecified: (:) [Copy-Item], DirectoryNotFoundExcept 
   ion
    + FullyQualifiedErrorId : System.IO.DirectoryNotFoundException,Microsoft.PowerSh 
   ell.Commands.CopyItemCommand

Как вы видите, для этой иллюстрации я поместил переменную (название телешоу) в «предложение», чтобы вы могли видеть добавленный к нему пробел. Я пробовал добавлять \s+, что удаляет один из пробелов, но я не могу избавиться от другого, независимо от того, использовал ли я трюк с обрезкой или нет.

Может кто-нибудь помочь? Спасибо, Коннор Брейсгедл.

решение1

Просто чтобы показать, что правильное регулярное выражение вполне способно
получить не только имя, но и все элементы, содержащиеся в имени файла,
используя группы захвата, заключающие части в скобки.

**EDIT см. RegEX в прямом эфиреhttps://regex101.com/r/Vbhq7D/1**

## Q:\Test\2018\06\10\SU_1330038.ps1
$TRANSFER = 'C:\Users\BRACEGIRDLE\Favorites\Desktop\TRANSFER\'
$TVSHOWS  = 'C:\Users\BRACEGIRDLE\Favorites\Desktop\TV_SHOW\'

$Pattern = '(.*)\s+S(\d{2})E(\d{2})[\- ]+(.*)'
Get-ChildItem $TVSHOWS *.txt| Where-Object BaseName -match $Pattern |
    ForEach-Object{
        $jon = Join-Path $TVSHOWS $Matches[1]

        If( -not (Test-Path $jon)) {
            New-Item -ItemType Directory -Force -Path $jon |Out-Null
        }
        $_ | Copy-Item -Destination $jon

        [pscustomobject]@{
            Name   = $Matches[1]
            Series = $Matches[2]
            Episode= $Matches[3]
            Title  = $Matches[4]
        }
    }

Скрипт создает подкаталог, копирует его, а также выводит следующий вывод:

Name         Series Episode Title
----         ------ ------- -----
12 Monkeys   02     10      Fatherland
Colony       02     01      Eleven Thirteen
Prison Break 05     05      Contingency    

Пример дерева на моем Ramdrive a:

> tree A: /F
A:\
│   12 Monkeys S02E10 - Fatherland.txt
│   Colony S02E01 - Eleven Thirteen.txt
│   Prison Break S05E05 - Contingency.txt
├───12 Monkeys
│       12 Monkeys S02E10 - Fatherland.txt
├───Colony
│       Colony S02E01 - Eleven Thirteen.txt
└───Prison Break
        Prison Break S05E05 - Contingency.txt

решение2

Проверьте результат -split. Он создает массив из 2 элементов

10JUN2018:012955 /:> $txts = Get-ChildItem "$TRANSFER/*.txt"
10JUN2018:012955 /:> ($txts[0].basename -split $pattern).GetType()

IsPublic IsSerial Name                                     BaseType                                                            
-------- -------- ----                                     --------                                                            
True     True     String[]                                 System.Array   
10JUN2018:012955 /:>"some random stuff" -split " stuff"
some random

10JUN2018:013239 /:>("some random stuff" -split " stuff")[0]
some random

Измененный код с доработкой:

$TRANSFER = "E:\Code\PS\myPS\2018\Jun\10"
$TVSHOWS = "E:\code\PS\myPS\2018\Jun\TV_SHOW\"
$pattern = ‘\s+\S[0-9][0-9].*’

Get-ChildItem "$TRANSFER/*.txt"| ForEach-Object {
    $target = ($_.BaseName -split $pattern)[0]
    Write-Host "$target@123"
    $jon = $TVSHOWS+$target
}

Выход:

12 Monkeys@123
Colony@123
Prison Break@123

Связанный контент