mv original.filename new.original.filename
如果不重新输入原始文件名,我该怎么办?
我会想象能够做类似mv -p=new. original.filename
或可能或其他的事情 - 但在查看/ pagesmv original.filename new.~
后我看不到这样的事情。man mv
info mv
当然,我可以编写一个 shell 脚本来执行此操作,但它没有现有的命令/标志吗?
您可以使用以下rename(1)
命令:
rename 's/(.*)$/new.$1/' original.filename
编辑:如果rename
不可用并且您必须重命名多个文件,那么 shell 脚本实际上可以很简短。例如,将 all 重命名*.jpg
为prefix_*.jpg
当前目录中的:
for filename in *.jpg; do mv "$filename" "prefix_${filename}"; done;
或者,利用Dave Webb 的回答并使用大括号扩展:
for filename in *.jpg; do mv {,prefix_}"$filename"; done;
在 Bash 和 zsh 中,您可以使用Brace Expansion来做到这一点。这只是扩展了大括号中的项目列表。例如:
# 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
您可以通过创建一个 for 循环来实现与 unix 兼容的多个文件重命名(使用通配符):
for file in *; do
mv $file new.${file%%}
done
我见过人们提到一个rename
命令,但它在 Unix 系统上通常不可用(与 Linux 系统或 Cygwin 不同——在这两者上,rename 是可执行文件而不是脚本)。该版本的rename
功能相当有限:
rename from to file ...
它将文件名的from部分替换为to,手册页中给出的示例是:
rename foo foo0 foo? foo??
这会将 foo1 重命名为 foo01,将 foo10 重命名为 foo010,等等。
我使用了一个名为 的 Perl 脚本rename
,我最初从大约 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
我知道这里有很好的答案,但在添加后缀时我发现没有处理文件扩展名的参考。
我需要wav
在文件扩展名之前为文件夹中的所有文件添加“_en”后缀。
魔法就在这里:%.*
for filename in *.wav; do mv $filename ${filename%.*}_en.wav; done;
如果您需要处理不同的文件扩展名,请检查此答案。不太直观。
批量重命名目录中文件的最简单方法是:
ls | xargs -I fileName mv fileName fileName.suffix
如果它可以修改,您可以使用后缀而不是前缀。然后您可以使用制表符完成来获取原始文件名并添加后缀。
否则,不,这不是 mv 命令支持的东西。不过,一个简单的 shell 脚本可以应付。
就我而言,我有一组文件需要重命名才能使用它们。每个文件在组中都有自己的角色,并且有自己的模式。
结果,我有一个像这样的重命名命令列表:
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
解决相同问题的另一种方法是创建映射数组并为每种文件类型添加 corespondent 前缀,如下所示:
#!/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
我不喜欢任何其他答案。
我的看法是你想要一个普通的 bash 解决方案。所以给你!
先用 echo 试试这个,看看会发生什么!
在对数千个文件使用命令之前测试您的命令!
如果要添加前缀,请删除“./”
find . -type f -exec bash -c 'echo prefix_${0#./}' {} \;
在提出的问题prefix_
中,new.
命令变成了
find . -type f -exec bash -c 'echo mv $0 new.${0#./}' {} \;
如果你想在它后面放一些东西,请删除扩展名
find . -type f -exec bash -c 'echo ${0%.*}_suffix.${0##*.}' {} \;
现在要使用它重命名只需将 echo 替换为mv $0
.
例子:
find . -type f -exec bash -c 'mv $0 1.${0#./}' {} \;
灵感来自: https ://gist.github.com/larshaendler/723d2ec447c3c694b71dc6e3bc3aadc9