欢迎光临
我们一直在努力

Linux文件名字批量修改步骤 Linux修改文件名的方法

  在Linux环境下修改文件名可以有不同的命令方式,比如rename、mv都可以进行修改,如果用户正在了解这方面的知识,可以阅读下文了解Linux修改文件名以及批量修改文件名的方法。

  对于单个的文件,可以直接使用命令,那如果有大量的类似格式的文件名需要修改成其他格式的,该如何呢?

  比如某次测试后,保存的文件为 Lan1.txt,Lan2.txt,……Lan100.txt

  这一百个文件需要在前面添加前缀变成类似 ch7_Lan1.txt,如果你还想使用mv来一个一个多痛苦啊。

  当前文件夹下,文件修改有四种方式:

  1、使用while Loop${//}来实现Lanch7_Lan的替换。

  1. 01find . -name "Lan*txt" -type f | read files
  2. 02do
  3. 03new=
  4. 04mv
  5. 05done

复制代码

find . -name "Lan*txt" -type f | read files
do
new=
mv
done

  2、充分利用awk的分隔符功能来实现:

  1. 01ls *Lan* | awk 'BEGIN{FS="Lan";OFS="ch7_Lan"}{printf "mv "$0" ";$1=$1;print $0}' | sh

复制代码

ls *Lan* | awk 'BEGIN{FS="Lan";OFS="ch7_Lan"}{printf "mv "$0" ";$1=$1;print $0}' | sh

  首先,修改FSOFS,输入和输出的分隔符。

  其次,使用awk中的命令,拼接“mv Lan1.txt ch7_Lan1.txt”这条命令。

  最后,使用|sh来执行一个shell命令来完成mv动作。

  其中,$1=$1是必须的,这个是完成Lan===> ch7_Lan的关键(其实是可以使用$2=$2等来替换,只要一个赋值动作而已)

  奇怪的是,难道没有赋值动作,分隔符的改变就不能检测出来么?

  3、使用awk的内置命令,gsubsystem来实现替换和命令执行。

  1. 01ls "*Lan*" | awk '{org=$0;gsub("Lan", "ch7_Lan");system("mv "org" "$1)}'

复制代码

ls "*Lan*" | awk '{org=$0;gsub("Lan", "ch7_Lan");system("mv "org" "$1)}'

  首先保存原始的数据。

  其次修改 Lan为 ch_Lan

  最后执行mv动作

  其中,最后system命令"mv "org"" 需要使用""来标记。

  而且org也需要"",并且不能使用$org

  1、对于awk命令中的变量,不需要用$来引用。

  2、在system()中,变量需要使用""来标识,否则就被当成字符串来处理。

  3、如果对变量进行$来进行引用,就会出现两种情况:

   3.1、正常情况下,可以被当成位置参数来引用。比如 NF表示当前行的记录个数。比如echo "a b c d" | awk '{print NF, $NF}',这个会打印两个变量,第一个是NF本身,其值为4;第二个是第四个位置参数,也就是$4,也就是d

   3.2、非正常情况下:

   3.2.1、如果变量本身就是个字符串。比如echo "a b c d" | awk '{va=“varA“;print va, $va}',因为后一个参数$va,由于va是个字符串,因此$va打印的就是$0

   3.2.2、如果变量本身就是个数字,但是该值大于NF。 比如echo "a b c d" | awk '{va="varA";vb=6;print va, $va, vb, $vb, 1}',因为$vb相当于是$6,但是位置参数$6没有,因此打印的就是个空字符。

  1. 01[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{print NF, }'
  2. 024 d
  3. 03[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";print va, }'
  4. 04varA a b c d
  5. 05[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";vb=6;print va, , vb, , 1}'
  6. 06varA a b c d 6 1

复制代码

[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{print NF, }'
4 d
[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";print va, }'
varA a b c d
[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";vb=6;print va, , vb, , 1}'
varA a b c d 6 1

  4、使用sed中的s来进行替换,然后使用e命令来执行:

  1. 01[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & \1ch_Lan\2/e'

复制代码

[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & \1ch_Lan\2/e'

  关于sed的选项,使用 -r-n

  -r 来启用后续可以使用 command,比如 mv

  -n 来关闭 patten space中内容的显示。

  关于sedcommand,使用e。如此在使用s命令完成 pattern spaceLanch7_Lan的修改后,启动shell来执行 pattern space中的 mv指令。

  如果这里使用 p,标记仅仅显示 pattern space中的指令而已。

  如果对于某目录下的所有文件,进行文件名修改,有两种方式:

  1、汇集awkFS/OFSgsub/system来实现。有点类似于综合上述2,3两种方式。

  1. 01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'

复制代码

[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'

  为了实现所有目录下的文件名进行修改,但是又不影响路径上文件夹名。

  首先,标记FS和OFS都为"/"。

  其次,使用gsub时候,指定仅仅修改当前行中最后一个记录,使用$NF来指定。

  当然,对于FSOFS的指定,可以不放置在 BEGIN中实现,比如:

  1. 01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -vF=/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'
  2. 02[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -F/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'

复制代码

[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -vF=/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'
[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -F/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'

  2、或者使用 sed

  1. 01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^\/]*)Lan([^\/]*)$/mv & \1\2ch7_Lan\3/e'

复制代码

[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^\/]*)Lan([^\/]*)$/mv & \1\2ch7_Lan\3/e'

  其中的各个 optioncommand参数,上述都已经有介绍了。

  这里,针对文件夹名和文件名,使用了简单的sed内置的正则表达式来进行匹配而已,来实现仅仅对文件名的修改。

  以上步骤在Linux修改文件名以及批量修改文件名的实现方式,是在shell中使用find、exec、xargs、mv命令组合批量替换文件名中的字符串。

赞(0)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《Linux文件名字批量修改步骤 Linux修改文件名的方法》
文章链接:https://pc.adminn.cn/1202.html
本站属非盈利性网站,不接受任何形式广告。本站提供文章纯教程分享,给网民提供教程,文章均采集网路,如侵犯您的权益,请联系我们删除,QQ:805750011。