Linux - Хочу проверить на возможные дублирующиеся каталоги (вероятно, необходимый RegEx)

У меня есть каталог, который содержит несколько каталогов следующим образом:

/Music/
/Music/JoeBlogs-Back_In_Black-1980
/Music/JoeBlogs-Back_In_Black-(Обновленный)-2003
/Music/JoeBlogs-Back_In_Black-(Переиздание)-1987
/Music/JoeBlogs-Thunder_Man-1947

Я хочу, чтобы сценарий прошел и сказал мне, когда существуют 'возможные' дубликаты, в примере выше его взял бы следующее как возможные дубликаты из списка каталога:

/Music/JoeBlogs-Back_In_Black-1980
/Music/JoeBlogs-Back_In_Black-(Обновленный)-2003
/Music/JoeBlogs-Back_In_Black-(Переиздание)-1987

1) Действительно ли это возможно?
2) Раз так помогите!

1
задан NoLongerHere 13 May 2010 в 14:30
поделиться

2 ответа

Продолжение:

Я сделал то, что мне нужно, написав следующий сценарий Perl. Это мой первый Perl-скрипт (и мне пришлось выучить Perl, чтобы написать его, так что не усердствуйте со мной :)

#!/usr/bin/perl

# README
# 
# Checks a folder for Albums that are similar 
# eg : 
# Arist-Back_In_Black-(Remastered)-2001-XXX
# Artist-Back_In_Black-(Reissue)-2000-YYY
#
# Script prompts you for which one to "zz" (putting zz in front of the file name you can delete it later)
#
# CONFIG
# 
# Put your mp3 directory path in the $mp3dirpath variable
#

$mp3dirpath = '/data/downloads/MP3';

# END CONFIG


@txt= qx{ls $mp3dirpath};


sort (@txt);

$re1='.*?'; 
$re2='(?:[a-z][a-z0-9_]*)';
$re3='.*?';
$re4='((?:[a-z][a-z0-9_]*))';

$re=$re1.$re2.$re3.$re4;

$foreach_count_before=0; #Setups up counter
$foreach_count_after=1; #Setups up counter


$number_in_arry = scalar (@txt);

while ($foreach_count_before < $number_in_arry) {
                                        if ($txt[$foreach_count_before] =~ m/$re/is)
                                            { 
                                             $var1=$1;
                                             }
                                         if ($txt[$foreach_count_after] =~ m/$re/is)
                                            { 
                                             $var2=$1;
                                             }
                                         if ($var1 eq $var2)
                                            {
                                             print "-------------------------------------\n";
                                             print "$txt[$foreach_count_before] \n";
                                             print "MATCHES \n";
                                             print "\n$txt[$foreach_count_after] \n";
                                             print "Which Should I Remove? \n";
                                             print "[1] $txt[$foreach_count_before]\n";
                                             print "[2] $txt[$foreach_count_after]\n";
                                             print "[Any Other Key] Take No Action\n\n";

                                             $answer = <>;        # Get user input, assign it to the variable 
                                                if    ( $answer == "1" ) { 
                                                      print "ZZing $txt[$foreach_count_before]";
                                                      $originalfilename = $mp3dirpath . '/' . $txt[$foreach_count_before];
                                                      $newfilename = $mp3dirpath . '/' . 'zz' . $txt[$foreach_count_before];
                                                      $originalfilename = trim($originalfilename);
                                                      $newfilename = trim($newfilename);
                                                      qx(mv $originalfilename $newfilename);
                                                } 
                                                elsif ( $answer == "2" ) { 
                                                      print "ZZing $txt[$foreach_count_after]";
                                                      $originalfilename = $mp3dirpath . '/' . $txt[$foreach_count_after];
                                                      $newfilename = $mp3dirpath . '/' . 'zz' . $txt[$foreach_count_after];
                                                      $originalfilename = trim($originalfilename);
                                                      $newfilename = trim($newfilename);
                                                      print "mv $originalfilename $newfilename";
                                                      qx(mv $originalfilename $newfilename);
                                                } 
                                                else { 
                                                      print "Taking No Action"; 
                                                }

                                            }

                                           $foreach_count_before++;
                                           $foreach_count_after++;

                                        }

# SubRoutine For Trimming White Space from variables
sub trim($)
{
 my $string = shift;
 $string =~ s/^\s+//;
 $string =~ s/\s+$//;
 return $string;
}
2
ответ дан 3 September 2019 в 00:34
поделиться

Если имена ваших каталогов имеют обычную структуру, например:

foo-Name_of_Interest-bar

, то вы можете использовать простое регулярное выражение, чтобы удалить «foo-» и «-bar» и провести прямое сравнение.

Если это невозможно, вам придется использовать гораздо более дорогой алгоритм сопоставления с образцом. Возможно, что-то вроде самой длинной общей последовательности или расстояния Левенштейна . Могут быть и другие методы, более подходящие.

Простое сопоставление в Bash (версия 3.2 или выше) может выглядеть следующим образом:

dir='/Music/JoeBlogs-Back_In_Black-(Remastered)-2003'
regex='^([^-]*)-([^-]*)-(.*)$'
if [[ ${BASH_REMATCH[1]} == ${prev_dir[1]} &&    #  "/Music/JoeBlogs"
      ${BASH_REMATCH[2]} == ${prev_dir[2]} ]]    #  "Back_In_Black"
then
    echo "we have a match"
fi

Этот фрагмент не показывает поиск ... | while read ... цикл или как обрабатывать предыдущие записи и списки совпадений.

0
ответ дан 3 September 2019 в 00:34
поделиться
Другие вопросы по тегам:

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