Как сравнить и отфильтровать файлы в каталоге с именем файла в текстовом файле или в листе Excel?

1511
AZUZ

У меня есть 100000 mp3-файлов в одном каталоге, каждый файл содержит произвольное имя файла, и у меня есть другой лист Excel, содержащий имя mp3-файла и имя, на которое он отображается. Есть ли способ разработать скрипт или стороннее программное обеспечение, которое может помочь разбить эти файлы на 3 разные папки

Пример:

  • В каталоге

Файл, такой как: fasf4a5465.mp3, fasdf35434.mp3, vefbgwsbgg.mp3

  • В Excel

    1. Столбец 1: имя файла = fasf4a5465.mp3, столбец 2 «Файловая группа» = группа1
    2. Столбец 1: Имя файла = fasdf35434.mp3, Столбец 2 «Файловая группа» = Группа2
    3. Столбец 1: Имя файла = vefbgwsbgg.mp3, Столбец 2 «Файловая группа» = Группа3

Таким образом, мой окончательный вывод будет три разные папки (группа 1, группа 2, группа 3), 100000 будут классифицированы в соответствии с таблицей Excel Excel

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

Любой обходной путь для этого?

3
Для ясности. У вас уже есть точные имена файлов в списке, и он называет группу, в которой вы хотите его найти. Правильно? Так что, если бы я попросил вас сделать три списка, скопируйте и вставьте group1 в файл блокнота и сохраните его как group1.txt, все имена в этом списке будут для нужной вам папки, да? Можете ли вы скопировать и пропустить электронную таблицу Excel, чтобы лучше понять, с чем работать? Решением может быть создание формулы для разделения списка на несколько отдельных списков, а затем использование программирования для создания папок и их перемещения в указанную папку. ejbytes 8 лет назад 1

1 ответ на вопрос

1
Pimp Juice IT

I have 100000 mp3 files in one directory, each file contain a random filename, and I have another excel sheet containing the mp3 file's name and to whom it maps to. Is there any way to develop a script or 3rd party software can help categorize these files into 3 different folder

  • In the Excel

    1. Column 1: File name = fasf4a5465.mp3, Column 2 'File Group' = Group1
    2. Column 1: File name = fasdf35434.mp3, Column 2 'File Group' = Group2
    3. Column 1: File name = vefbgwsbgg.mp3, Column 2 'File Group' = Group3

Okay, so it's a script you want to do this then Powershell to the rescue with the below logic.

PowerShell Script Variables Explained

  • $ExcelFile =
    • You will need to make this variable point to your XLS or XLSX file (yes either one will work) which contains the mappings, or the column values per row which the first column is the MP3 file name and the second column is the group name or the new subfolders these files will be copied to.
  • $CSVFile =
    • You will need to make this variable point to the CSV converted temporary file (based on what's in the Excel ($ExcelFile)) for the rest of the logic to do it's magic. If this file already exists, I put the logic to overwrite it so no worries on a static file name.
  • $MP3SourceDir =
    • You will need to make this variable point to your MP3 source directory where these file will be grabbed from initially based on the file names from first column in the Excel spreadsheet. Warning: you MUST keep the \$($_.first) logic in this logic—just plug in the other path part only.
  • $NewMP3Dir =
    • You will need to make this variable point to the new location where the new [group] second column folders will be created for the applicable first column MP3 files to be copied. Warning: you MUST keep the \$($_.second) logic in this logic—just plug in the other path part only.

PowerShell Script Example

$ExcelFile = "C:\Path\Excel Worksheet.xlsx" $CSVFile = "C:\Path\ExportCSV.csv" $Excel = New-Object -ComObject excel.application $Excel.visible = $False $Excel.displayalerts = $False $WorkBook = $Excel.Workbooks.Open("$ExcelFile") $WorkSheet = $Workbook.worksheets.Item(1) If (Test-Path $CSVFile){ Remove-Item $CSVFile } $WorkBook.SaveAs("$CSVFile", 6) $Excel.quit() Import-Csv "$CSVFile" -Header ("first","second") | ForEach { $MP3SourceDir = "D:\Path\SourceMP3\$($_.first)" $NewMP3Dir = "D:\Path\NewMP3\$($_.second)" New-Item -ItemType Dir "$NewMP3Dir" -Force Copy-Item "$MP3SourceDir" -Destination "$NewMP3Dir\$($_.first)" -Force } 

(Note this is the source I got the logic idea from for the xls to csv conversion to then read the delimited values in the csv file to then do the rest so I made many adjustments as well)

(This script essentially takes an existing XLS or XLSX file with two column [mapping] values in column A and column B (all rows), and saves it in CSV format to another CSV file. It then reads from that CSV file and the CSV value of column A (per line or row) is used as the file name to copy to another folder (or subfolder), which is the column B CSV value (on the same line or row). Each line or row should contain two values with the first being a file name and the second being a folder name—these are the values looped through running the commands to copy, etc.)

Source: PowerShell XLS to CSV


Further PowerShell Command Reading

@AZUZ Пожалуйста, дайте мне знать, если мой ответ помог решить вашу проблему, а также, пожалуйста, просмотрите [** Принятие ответа **] (http://meta.stackexchange.com/questions/5234/how-does-accepting-an-answer -работать), чтобы убедиться, что вы понимаете, как этот сайт вопросов и ответов работает, чтобы замкнуть цикл на ваши вопросы, чтобы получить ответ, который поможет решить ваши проблемы. Это так же просто, и отметьте галочкой рядом с ответом, который решает вашу проблему. Pimp Juice IT 8 лет назад 0

Похожие вопросы