Вопрос

Как мне это сделать mv original.filename new.original.filename без повторного ввода исходного имени файла?

Я мог бы представить, что смогу сделать что-то вроде mv -p=new. original.filename или возможно mv original.filename new.~ или что-то в этом роде, но я не вижу ничего подобного после просмотра man mv / info mv страницы.

Конечно, я мог бы написать для этого сценарий оболочки, но разве для этого нет существующей команды/флага?

Это было полезно?

Решение

В Bash и zsh вы можете сделать это с помощью Расширение скобок.Это просто расширяет список элементов в фигурных скобках.Например:

# echo {vanilla,chocolate,strawberry}-ice-cream
vanilla-ice-cream chocolate-ice-cream strawberry-ice-cream

Итак, вы можете переименовать следующим образом:

mv {,new.}original.filename

поскольку это расширяется до:

mv original.filename new.original.filename

Другие советы

Вы можете использовать команду rename(1):

rename 's/(.*)$/new.$1/' original.filename

Редактировать: Если переименование недоступно и вам нужно переименовать более одного файла, для этого сценарии оболочки могут быть короткими и простыми.Например, чтобы переименовать все .jpg до префикса_.jpg в текущем каталоге:

for filename in *.jpg; do mv "$filename" "prefix_$filename"; done;

Вы можете добиться переименования нескольких файлов, совместимого с Unix (с использованием подстановочных знаков), создав цикл for:

for file in *; do
  mv $file new.${file%%}
done

Я видел, как люди упоминали rename команда, но она обычно недоступна в системах Unix (в отличие, скажем, от систем Linux или Cygwin — в обеих системах rename является исполняемым файлом, а не сценарием).Эта версия rename имеет довольно ограниченный функционал:

rename from to file ...

Он заменяет от часть имен файлов с к, и пример, приведенный на странице руководства:

rename foo foo0 foo? foo??

Это переименовывает foo1 в foo01, foo10 в foo010 и т. д.

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

#!/bin/perl -w
#
# @(#)$Id: rename.pl,v 1.7 2008/02/16 07:53:08 jleffler Exp $
#
# Rename files using a Perl substitute or transliterate command

use strict;
use Getopt::Std;

my(%opts);
my($usage) = "Usage: $0 [-fnxV] perlexpr [filenames]\n";
my($force) = 0;
my($noexc) = 0;
my($trace) = 0;

die $usage unless getopts('fnxV', \%opts);

if ($opts{V})
{
    printf "%s\n", q'RENAME Version $Revision: 1.7 $ ($Date: 2008/02/16 07:53:08 $)';
    exit 0;
}
$force = 1 if ($opts{f});
$noexc = 1 if ($opts{n});
$trace = 1 if ($opts{x});

my($op) = shift;
die $usage unless defined $op;

if (!@ARGV) {
    @ARGV = <STDIN>;
    chop(@ARGV);
}

for (@ARGV)
{
    if (-e $_ || -l $_)
    {
        my($was) = $_;
        eval $op;
        die $@ if $@;
        next if ($was eq $_);
        if ($force == 0 && -f $_)
        {
            print STDERR "rename failed: $was - $_ exists\n";
        }
        else
        {
            print "+ $was --> $_\n" if $trace;
            print STDERR "rename failed: $was - $!\n"
                unless ($noexc || rename($was, $_));
        }
    }
    else
    {
        print STDERR "$_ - $!\n";
    }
}

Это позволяет вам написать любую команду-заменитель или транслитерацию Perl для сопоставления имен файлов.В конкретном запрошенном примере вы должны использовать:

rename 's/^/new./' original.filename

Самый простой способ массового переименования файлов в каталоге:

ls | xargs -I fileName mv fileName fileName.suffix

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

В противном случае нет, это не поддерживается командой mv.Однако простой сценарий оболочки мог бы справиться.

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

В результате у меня есть такой список команд переименования:

f=`ls *canctn[0-9]*`   ;  mv $f  CNLC.$f
f=`ls *acustb[0-9]*`   ;  mv $f  CATB.$f
f=`ls *accusgtb[0-9]*` ;  mv $f  CATB.$f
f=`ls *acus[0-9]*`     ;  mv $f  CAUS.$f

Попробуйте еще это:

f=MyFileName; mv $f {pref1,pref2}$f{suf1,suf2}

Это создаст все комбинации с префиксами и суффиксами:

pref1.MyFileName.suf1
...
pref2.MyFileName.suf2

Другой способ решить ту же проблему — создать массив сопоставлений и добавить префикс корреспондента для каждого типа файла, как показано ниже:

#!/bin/bash
unset masks
typeset -A masks
masks[ip[0-9]]=ip
masks[iaf_usg[0-9]]=ip_usg
masks[ipusg[0-9]]=ip_usg
...
for fileMask in ${!masks[*]}; 
do  
registryEntry="${masks[$fileMask]}";
fileName=*${fileMask}*
[ -e ${fileName} ] &&  mv ${fileName} ${registryEntry}.${fileName}  
done

Скрипт массового переименования файлов bash

#!/bin/bash
# USAGE: cd FILESDIRECTORY; RENAMERFILEPATH/MultipleFileRenamer.sh FILENAMEPREFIX INITNUMBER
# USAGE EXAMPLE: cd PHOTOS; /home/Desktop/MultipleFileRenamer.sh 2016_
# VERSION: 2016.03.05.
# COPYRIGHT: Harkály Gergő | mangoRDI (https://wwww.mangordi.com/) 

# check isset INITNUMBER argument, if not, set 1 | INITNUMBER is the first number after renaming
if [ -z "$2" ]
    then i=1;
else
    i=$2;
fi

# counts the files to set leading zeros before number | max 1000 files
count=$(ls -l * | wc -l)
if [ $count -lt 10 ]
    then zeros=1;
else
    if [ $count -lt 100 ]
        then zeros=2;
    else
        zeros=3
    fi
fi

# rename script
for file in *
do
    mv $file $1_$(printf %0"$zeros"d.%s ${i%.*} ${file##*.})
    let i="$i+1"
done
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top