元のファイル名を再入力せずに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の名前をprefix _。jpgに変更するには:
for filename in *.jpg; do mv "$filename" "prefix_$filename"; done;
Forループを作成することで、Unix互換の複数ファイルの名前変更(ワイルドカードを使用)を実現できます。
for file in *; do
mv $file new.${file%%}
done
私は人々がrename
コマンドに言及しているのを見たことがありますが、Unixシステムでは定期的に利用できません(Linuxシステム、たとえば、またはCygwinとは対照的に-どちらも名前変更はスクリプトではなく実行可能です) 。 rename
のそのバージョンには、かなり制限された機能があります。
rename from to file ...
ファイル名のfrom部分をtoに置き換えます。マニュアルページに記載されている例は次のとおりです。
rename foo foo0 foo? foo??
これにより、foo1がfoo01に、foo10がfoo010に、などの名前が変更されます。
rename
と呼ばれるPerlスクリプトを使用します。これは、1992年頃の最初のエディションのCamelの本から最初に掘り下げてから、ファイルの名前を変更するために拡張しました。
#!/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コマンドでサポートされているものではありません。ただし、単純なシェルスクリプトで対処できます。
一括名前変更ファイル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
私の場合、ファイルを操作する前に名前を変更する必要があるファイルのグループがあります。各ファイルにはグループ内で独自の役割があり、独自のパターンがあります。
その結果、次のような名前変更コマンドのリストがあります。
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