如何在不重新输入原始文件名的情况下mv original.filename new.original.filename
进行操作?
我会想象能够做mv -p=new. original.filename
或mv original.filename new.~
或其他任何事情 - 但在查看man mv
/ info mv
之后我看不到这样的事情页。
当然,我可以编写一个shell脚本来执行此操作,但是不存在现有的命令/标志吗?
答案 0 :(得分:133)
您可以使用rename(1)命令:
rename 's/(.*)$/new.$1/' original.filename
编辑:如果重命名不可用且您必须重命名多个文件,那么shell脚本可能非常简短。例如,要将所有 .jpg重命名为当前目录中的前缀_ .jpg:
for filename in *.jpg; do mv "$filename" "prefix_$filename"; done;
答案 1 :(得分:109)
在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
答案 2 :(得分:24)
您可以通过创建for循环来实现与unix兼容的多文件重命名(使用通配符):
for file in *; do
mv $file new.${file%%}
done
答案 3 :(得分:8)
我见过人们提到了一个rename
命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或Cygwin),在这两个系统上,重命名是一个可执行文件而不是一个脚本)。该版本的rename
功能相当有限:
rename from to file ...
它用替换 文件名的到,手册页中给出的例子是:
rename foo foo0 foo? foo??
这会将foo1重命名为foo01,将foo10重命名为foo010等。
我使用名为rename
的Perl脚本,我最初从第一版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
答案 4 :(得分:2)
如果它可以修改,您可以使用后缀而不是前缀。然后,您可以使用制表符完成来获取原始文件名并添加后缀。
否则,这不是mv命令支持的内容。一个简单的shell脚本可以应付。
答案 5 :(得分:2)
批量重命名目录中文件的最简单方法是:
ls | xargs -I fileName mv fileName fileName.suffix
答案 6 :(得分:2)
我知道这里有很好的答案,但是添加后缀时没有找到处理文件扩展名的参考。
我需要在文件扩展名之前为文件夹中的所有wav
文件添加'_en'后缀。
魔术在这里:%.*
for filename in *.wav; do mv $filename ${filename%.*}_en.wav; done;
如果您需要处理其他文件扩展名,请检查this答案。不太直观。
答案 7 :(得分:1)
在我的情况下,我有一组文件需要重命名才能使用它们。每个文件在组中都有自己的角色,并且有自己的模式。
结果我有一个重命名命令列表,如下所示:
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
答案 8 :(得分:1)
批量重命名文件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
答案 9 :(得分:0)
我不喜欢任何答案。我的看法是您需要一个 vanilla bash 解决方案。就这样吧!
先用 echo 试试这个,看看会发生什么!在对数千个文件使用命令之前先对其进行测试!
去掉'./'是要加前缀吗
find . -type f -exec bash -c 'echo prefix_${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