shell 实现文件改名

修改文件名可以有不同的命令方式,mv 可以实现,但是使用rename 这种专业的改名字很好

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

创建测试文件:  touch hell_world_hi_{1..5}_OO.jpg

这一百个文件需要在前面添加前缀变成类似hell_world_hi_{1..5}_nihao.jpg,如果你使用那啥一个一个来,太不运维了

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

1. 使用while Loop加 ${//}来实现OO到 nihao 的替换

#!/bin/bash
#################################################
#    File Name: name01.sh
#       Author: kingle
#         Mail: kingle_work@163.com
#     Function:
# Created Time: 2018年11月06日 星期二 15时27分18秒
#################################################
ls hell_*|while read files
do
    REN=${files/OO/nihao}
    mv $files $REN
done


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

 

  在完成前应该先来学学awk的OFS的神操作

[root@kingle ~]# echo "abc" | awk '{ OFS="." } { NF=NF; print NF,$0}'
1.abc

首先,修改 FS和 OFS,输入和输出的分隔符

 

[root@kingle conpa]# ls hell_world_hi_*|awk 'BEGIN{FS="nihao";OFS="enen"}{printf "mv "$0 " ";$1=$1;print $0}'|bash


其次,使用 awk中的命令,拼接 mv hell_world_hi_1_nihao.jpg hell_world_hi_1_enen.jpg”这条命令
最后,使用|bash来执行一个 shell命令来完成 mv动作

其中,$1=$1是必须的,这个是完成hell_world_hi_1_nihao.jpg===> hell_world_hi_1_enen.jpg的关键(其实是可以使用 $2=$2等来替换,只要一个赋值动作而已)
奇怪的是,难道没有赋值动作,分隔符的改变就不能检测出来么??



3. 使用 awk的内置命令,gsub和 system来实现替换和命令执行

 

 [root@kingle conpa]# ls hell* | awk '{org=$0;gsub("nihao", "enen");system("mv "org" "$0)}' 

首先保存原始的数据
其次修改 nihao为 enne
最后通过awk内置执行mv动作

其中,最后system命令”mv “org” “需要使用”“来标记,
而且 org也需要”“,并且不能使用$org
1. 对于 awk命令中的变量,不需要用 $来引用
2. 在system()中,变量需要使用""来标识,否则就被当成字符串来处理
3. 如果对变量进行 $来进行引用,就会出现两种情况
   3.1 正常情况下,可以被当成位置参数来引用。比如 NF表示当前行的记录个数。比如

   [root@kingle conpa]# echo "a b c d" | awk '{print NF, $NF}' 4 d 

  这个会打印两个变量,第一个是 NF本身,其值为4;第二个是第四个位置参数,也就是 $4,也就是 d
   3.2 非正常情况下:
      3.2.1 如果变量本身就是个字符串。比如

   [root@kingle conpa]# echo "a b c d" | awk '{va="varA";print va, $va}'

                varA a b c d 

  因为后一个参数$va,由于va是个字符串,因此 $va打印的就是 $0
       3.2.2 如果变量本身就是个数字,但是该值大于 NF。 比如

   1 [root@kingle conpa]# echo "a b c d" | awk '{va="varA";vb=6;print va, $va, vb, $vb, 1}'      

   2 varA a b c d 6 1 

    因为 $vb相当于是 $6,但是位置参数 $6没有,因此打印的就是个空字符


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

 

[root@kingle conpa]#  ls hell_world_* | sed -r -n 's/(.*)hi(.*)/mv & \1hello\2/e'

 

关于sed的选项,使用 -r和 -n
-r 来启用后续可以使用 command,比如 mv
-n 来关闭 patten space中内容的显示

关于sed的 command,使用e。如此在使用s命令完成 pattern space中hi到 hello的修改后,启动shell来执行 pattern space中的 mv指令
如果这里使用 p,标记仅仅显示  pattern space中的指令而已


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

1. 汇集awk的 FS/OFS和 gsub/system来实现。有点类似于综合上述2,3两种方式

 
  

为了实现所有目录下的文件名进行修改,但是又不影响路径上文件夹名
首先,标记FS和OFS都为 ”/“
其次,使用gsub时候,指定仅仅修改当前行中最后一个记录,使用 $NF来指定

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

  
[root@kingle conpa]# find . -name "*world*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("hello", "hi", $NF);system("echo "org" "$0)}'
./hell_world_hello_5_enen.jpg ./hell_world_hi_5_enen.jpg
./hell_world_hello_1_enen.jpg ./hell_world_hi_1_enen.jpg
./hell_world_hello_3_enen.jpg ./hell_world_hi_3_enen.jpg
./hell_world_hello_4_enen.jpg ./hell_world_hi_4_enen.jpg
./hell_world_hello_2_enen.jpg ./hell_world_hi_2_enen.jpg

 

[root@kingle conpa]# find . -name "*world*" -type f | awk 'BEGIN{FS="/";OFS="/"}{org=$0;gsub("hello", "hi", $NF);system("mv "org" "$0)}'

 

2. 或者使用 sed

[root@kingle conpa]#  find . -name "*hell*" -type f | sed -r -n 's/(.*)([^\/]*)hi([^\/]*)$/mv & \1\2hello\3/e'

 

3,专业修

 

[root@kingle conpa]# rename hello hi *.jpg

 

-rw-r--r-- 1 root root   0 11月  6 15:24 hell_world_hi_1_enen.jpg
-rw-r--r-- 1 root root   0 11月  6 15:24 hell_world_hi_2_enen.jpg
-rw-r--r-- 1 root root   0 11月  6 15:24 hell_world_hi_3_enen.jpg
-rw-r--r-- 1 root root   0 11月  6 15:24 hell_world_hi_4_enen.jpg
-rw-r--r-- 1 root root   0 11月  6 15:24 hell_world_hi_5_enen.jpg

4,去除某个不需要的重复名字 

#!/bin/bash
#################################################
#    File Name: name02.sh
#       Author: kingle
#         Mail: kingle_work@163.com
#     Function:
# Created Time: 2018年11月06日 星期二 16时06分16秒
#################################################
for file in `ls *world*.jpg`
do
    mv $file `echo ${file//_hi/}`
done

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

转载于:https://www.cnblogs.com/kingle-study/p/9913165.html

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是一个示例 shell 脚本,可以实现在一个文件夹中搜索名字包含 "AI" 的文件: ``` #!/bin/bash # 指定文件夹的路径 folder_path="./" # 使用 find 命令搜索文件 results=$(find "$folder_path" -type f -name "*AI*") # 输出结果 echo "包含 'AI' 名字的文件:" echo "$results" ``` 该脚本会在当前文件夹中搜索名字包含 "AI" 的文件,并将结果输出到终端。你可以通过修改 `folder_path` 变量的值,指定不同的文件夹路径。 ### 回答2: 可以使用以下的shell脚本来实现在一个文件夹搜索包含"AI"名字的文件: ```bash #!/bin/bash # 定义要搜索的文件夹路径 folder="/path/to/folder" # 使用find命令搜索文件夹中包含"AI"名字的文件,并将结果保存到变量files中 files=$(find $folder -type f -name "*AI*") # 检查是否有包含"AI"名字的文件 if [ -z "$files" ]; then echo "没有找到包含AI名字的文件。" else echo "找到以下包含AI名字的文件:" echo "$files" fi ``` 请将`/path/to/folder`替换为实际的文件夹路径。此脚本将使用`find`命令在指定的文件夹中搜索包含"AI"名字的文件,并将结果保存到变量`files`中。然后,脚本将检查是否有找到符合条件的文件,并打印出结果。如果找到了文件,则会输出包含"AI"名字的文件列表。如果没有找到文件,则会显示一条找不到文件的消息。 ### 回答3: 编写一个shell脚本可以使用`find`命令来实现在一个文件夹中搜索包含“AI”名字的文件。以下是一个示例脚本: ```shell #!/bin/bash # 设置要搜索的文件夹路径 folder="/path/to/search" # 使用find命令来搜索包含“AI”名字的文件,并将结果保存到一个变量中 result=$(find $folder -name "*AI*") # 检查结果是否为空 if [ -z "$result" ]; then echo "没有找到包含“AI”名字的文件。" else echo "找到的包含“AI”名字的文件如下:" echo "$result" fi ``` 需要替换脚本中的`/path/to/search`为要搜索的文件夹的实际路径。该脚本使用`find`命令来搜索名字中包含“AI”的文件,并将结果保存到`result`变量中。然后检查结果是否为空,如果不为空,就打印出找到的文件列表。如果结果为空,则打印出“没有找到包含“AI”名字的文件。”的消息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值