如何在不重新输入原始文件名的情况下执行 mv original.filename new.original.filename

我会想象能够做像 mv -p = new这样的事情。 original.filename 或者也许 mv original.filename new .~ 或者其他什么 - 但是看了 man mv / info mv 页面。

当然,我可以编写一个shell脚本来执行此操作,但是不存在现有的命令/标志吗?

有帮助吗?

解决方案

在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

其他提示

您可以使用rename(1)命令:

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

编辑:如果重命名不可用且您必须重命名多个文件,那么shell脚本可能非常简短。例如,要将所有 .jpg重命名为当前目录中的前缀_ .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 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: 
rename 's/^/new./' original.filename
[-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

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*> || -l

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>) { my($was) =

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>; eval $op; die $@ if $@; next if ($was eq

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>); if ($force == 0 && -f

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>) { print STDERR "rename failed: $was -

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*> exists\n"; } else { print "+ $was -->

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>\n" if $trace; print STDERR "rename failed: $was - $!\n" unless ($noexc || rename($was,

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>)); } } else { print STDERR "

我见过人们提到了 rename 命令,但是在Unix系统上并不是常规可用的(而不是Linux系统,比如说,或者是Cygwin),两者都重命名是可执行文件而不是脚本)。该版本的重命名具有相当有限的功能:

rename from to file ...

它用替换 文件名的,手册页中给出的例子是:

rename foo foo0 foo? foo??

这会将foo1重命名为foo01,将foo10重命名为foo010等。

我使用名为 rename 的Perl脚本,我最初从第一版Camel书中挖出,大约在1992年,然后扩展,重命名文件。

<*>

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*> - $!\n"; } }

这允许您编写任何Perl替换或音译命令来映射文件名。 在请求的具体示例中,您将使用:

<*>

批量重命名目录中文件的最简单方法是:

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
许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top