⑴ linux批量修改文件后缀名Linux下批量修改文件名的方法
linux批量修改文件后缀名,Linux下批量修改文件名的方法很多人还不知道,现在让我们一起来看看吧!
Linux下批量修改文件名的方法
在Linux环境下修改文件名可以有不同的命令方式,比如rename、mv都可以进行修改,如果用户正在了解这方面的知识,可以阅读下文了解Linux修改文件名以及批量修改文件名的方法。
对于单个的文件,可以直接使用命令,那如果有大量的类似格式的文件名需要修改成其他格式的,该如何呢?
比如某次测试后,保存的文件为 Lan1.txt,Lan2.txt,……Lan100.txt
这一百个文件需要在前面添加前缀变成类似 ch7_Lan1.txt,如果你还想使用mv来一个一个多痛苦啊。
当前文件夹下,文件修改有四种方式:
1、使用while Loop加${//}来实现Lan到ch7_Lan的替换。
01find . -name "Lan*txt" -type f | read files02do03new=04mv05done复制代码
find . -name "Lan*txt" -type f | read filesdonew=mvdone
2、充分利用awk的分隔符功能来实现:
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
首先,修改FS和OFS,输入和输出的分隔符。
其次,使用awk中的命令,拼接“mv Lan1.txt ch7_Lan1.txt”这条命令。
最后,使用|sh来执行一个shell命令来完成mv动作。
其中,$1=$1是必须的,这个是完成Lan===> ch7_Lan的关键(其实是可以使用$2=$2等来替换,只要一个赋值动作而已)
奇怪的是,难道没有赋值动作,分隔符的改变就不能检测出来么?
3、使用awk的内置命令,gsub和system来实现替换和命令执行。
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没有,因此打印的就是个空字符。
01[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{print NF, }'024 d03[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";print va, }'04varA a b c d05[martin@TSPerPacketsTest]$ echo "a b c d" | awk '{va="varA";vb=6;print va, , vb, , 1}'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命令来执行:
01[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & 1ch_Lan2/e'复制代码
[martin@TSPerPacketsTest]$ ls *Lan* | sed -r -n 's/(.*)Lan(.*)/mv & 1ch_Lan2/e'
关于sed的选项,使用 -r和 -n
-r 来启用后续可以使用 command,比如 mv
-n 来关闭 patten space中内容的显示。
关于sed的 command,使用e。如此在使用s命令完成 pattern space中 Lan到 ch7_Lan的修改后,启动shell来执行 pattern space中的' mv指令。
如果这里使用 p,标记仅仅显示 pattern space中的指令而已。
如果对于某目录下的所有文件,进行文件名修改,有两种方式:
1、汇集awk的 FS/OFS和 gsub/system来实现。有点类似于综合上述2,3两种方式。
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来指定。
当然,对于FS和OFS的指定,可以不放置在 BEGIN中实现,比如:
01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | awk -vF=/ -vOFS=/ '{org=$0;gsub("Lan", "ch7_Lan", );system("echo "org" "$0)}'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。
01[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^/]*)Lan([^/]*)$/mv & 12ch7_Lan3/e'复制代码
[martin@TSPerPacketsTest]$ find . -name "*Lan*" -type f | sed -r -n 's/(.*)([^/]*)Lan([^/]*)$/mv & 12ch7_Lan3/e'
其中的各个 option和 command参数,上述都已经有介绍了。
这里,针对文件夹名和文件名,使用了简单的sed内置的正则表达式来进行匹配而已,来实现仅仅对文件名的修改。
以上步骤在Linux修改文件名以及批量修改文件名的实现方式,是在shell中使用find、exec、xargs、mv命令组合批量替换文件名中的字符串。
⑵ linux命令怎么把一个文档下的所有文件都改名
|1.用for灵活,文件名中字符替换,加日期等都可
先用下面语句测试一下
for i in *aa* ;do NN=$(echo $i |内 sed 's/aa/bb/') ;echo "$NN";done
保险容起见,只拷贝
for i in *aa* ;do NN=$(echo $i | sed 's/aa/bb/') ;cp "$i" "$NN";done
这是更名,慎用
for i in *aa* ;do NN=$(echo $i | sed 's/aa/bb/') ;mv "$i" "$NN";done
2.用rename简洁
先用-n开关测试
rename -n 's/aa/bb/' *
测试无误去掉-n进行更名
rename 's/aa/bb/' *
⑶ Linux|如何查找和删除重复文件
在Linux系统管理文件时,处理重复文件是一项繁琐的任务,特别是当你经常从网络下载资料时。本文将教你如何利用 rdfind、fpes、rmlint、DupeGuru 和 FSlint 等命令行工具以及图形界面程序来识别和移除这些不必要的重复文件,同时强调谨慎操作以避免误删重要数据。
这个免费的命令行工具 rdfind(重复数据查找)可在单个或跨目录中搜索重复文件,它会深入检查文件内容,帮助你决定保留哪个版本。安装后,只需输入命令和目标目录,结果会保存在名为 results.txt 的文件中。使用 -dryrun 选项可查看重复文件列表,而不执行操作。考虑使用硬链接替换重复文件或通过 -d 选项删除。
安装 fpes 后,用法与 rdfind 类似。通过指定目录和选项,如 -r 递归搜索,-S 显示大小,-m 提供汇总信息,-d 删除重复项,但避免使用 -N 仅保留第一个文件。查看帮助文档以获取更多信息。
Rmlint 专注于查找和清理类似 lint 的重复或冗余文件,包括空文件和损坏的链接。安装后,它能帮助你识别和清理系统中的这些问题。
跨平台的开源工具 peGuru 适合寻找文件名或内容的重复,提供模糊匹配功能。安装后,可以在不同平台如Linux上使用,帮助你精确地找到和清理重复文件。
FSlint 是一个免费的清理工具,能检测重复文件、空目录等,支持命令行和图形界面操作。安装后,可根据需要使用其功能进行系统清理。
总的来说,这些工具是Linux系统中查找和处理重复文件的强大武器,但在操作前务必备份重要数据,确保安全地清理您的文件系统。
⑷ linux修改文件名linux批量改文件名解决方法
本文将详细介绍linux如何修改文件名 linux 如何批量改文件名解决方法,需要了解更多的朋友可以参考下今天在删这种文件名删到恶心:
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rw-r--r--0.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rw-r--r--1.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rw-r--r--2.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rw-r--r--3.l
-rw-r--r-- 1 work work 64 Mar 26 17:27 -rw-r--r--.r
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rwxr--r--0.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rwxr--r--1.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rwxr--r--2.l
-rw-r--r-- 1 work work 0 Mar 26 17:27 -rwxr--r--3.l
-rw-r--r-- 1 work work 64 Mar 26 17:27 -rwxr--r--.r
具体办法:
Linux中"-"有特殊的含义,比如在命令的后面加"-"表示后面跟的是选项。但是如何新建带名字中有"-",下面介绍三种方法,比如要新建文件"-a":
1、cd . > -a
2、vi -- -a
3、echo "" > -a
上面三种方法都可以在当前目录下新建一个"-a"文件,当然还可以有别的方法新建,这里就不在介绍。如果要删除"-a"就比较麻烦了,如果你输入 rm -a,系统会提示你:
rm:无效选项 -- a
请尝试执行‘rm --help’来获取更多信息。
对于这样的文件可以有两种方法来删除,如下所示:
1、rm ./-a
2、rm -- -a
改名字也不用说了,基本上就是在文件名前面加"--"来表示转义字符就可以了!