
ファイル名から一部のデータを抽出する際に問題があります。抽出した名前の末尾にスペースが追加されているようで、.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
ご覧のとおり、この図では変数 (テレビ番組名) を「文」に入れて、スペースが追加されているのを確認できるようにしています。スペースの 1 つを削除する \s+ を追加してみましたが、トリム トリックを使用するかどうかに関係なく、もう 1 つのスペースを削除することはできません。
誰か助けてくれませんか、ありがとう、コナー・ブレイスガードル
答え1
適切な正規表現は、括弧で囲まれた部分をキャプチャグループを使用して、
名前だけでなくファイル名に含まれるすべての要素を取得できることを非常によく示しています。
**編集 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