WedX - журнал о программировании и компьютерных науках

Powershell Переименовать файлы, если имя содержит ‹string›

Я пытаюсь добавить PatientOrderNumber к имени файлов в каталоге, если имя файла включает уникальный идентификатор из моего CSV-файла. Я пробовал параметры -like и -contains, но безуспешно.

вот мой код:

$csvPath = "C:\Users\dougadmin28\Desktop\Test\1bs4e.csv"
## Variable to hold path of Files that need to be renamed ##
$filePath = "C:\Users\dougadmin28\Desktop\Node Modify File Name App\pdfs" 

$csv = Import-Csv $csvPath #| Select-Object -Property PatientOrderNumber, FileID, DocumentID, LastName, FirstName|Export-Csv 'C:\Users\dougadmin28\Desktop\Node Modify File Name App\documents.csv'

$files = Get-ChildItem $filePath 


    foreach ($item in $csv){  



            foreach($file in $files)  {     
               if($file.FullName -contains '*$item.DocumentID*') {

                Rename-Item $file.FullName -NewName "$($item.PatientOrderNumber+"_"+($item.FileID)+'_'+($item.DocumentID)+'_'+($item.LastName)+'_'+($item.FirstName)+($file.extension))" 

            }#End forEach

        }#End if

    } #End forEach```
24.09.2019

Ответы:


1

tl; dr

Вместо:

$file.FullName -contains '*$item.DocumentID*' # WRONG

использовать:

$file.FullName -like "*$($item.DocumentID)*"

Обратите внимание на использование " вместо ' и $(...) вокруг выражения доступа к свойству.


Что касается того, что вы пробовали:

$file.FullName -contains '*$item.DocumentID*'

  • -contains проверяет членство RHS в LHS, имеющем значение массива, но не выполняет сопоставление подстрок.

    • See this answer for the difference between PowerShell's -contains operator and the String.Contains() .NET method.
  • '...' строки принимаются буквально (дословно), поэтому расширение (интерполяция) не выполняется; "..." (расширяемые строки) должны использоваться для интерполяции строк.

  • Внутри расширяемой строки могут быть встроены только простые ссылки на переменные (например, $item) как есть; что-либо более сложное, например выражение, которое включает доступ к свойству (например, $item.DocumentID), требует включения в $(...), оператора подвыражения.

    • See this answer for an overview of string expansion (interpolation) in PowerShell.
24.09.2019
Новые материалы

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..

Учебные заметки: создание моего первого пакета Node.js
Это мои обучающие заметки, когда я научился создавать свой самый первый пакет Node.js, распространяемый через npm. Оглавление Глоссарий I. Новый пакет 1.1 советы по инициализации..

Забудьте о Matplotlib: улучшите визуализацию данных с помощью умопомрачительных функций Seaborn!
Примечание. Эта запись в блоге предполагает базовое знакомство с Python и концепциями анализа данных. Привет, энтузиасты данных! Добро пожаловать в мой блог, где я расскажу о невероятных..

ИИ в аэрокосмической отрасли
Каждый полет – это шаг вперед к великой мечте. Чтобы это происходило в их собственном темпе, необходима команда астронавтов для погони за космосом и команда технического обслуживания..


Для любых предложений по сайту: [email protected]