Linux shell 提取文件名和目录名的方法

很多时候在使用Linux的shell时,我们都需要对文件名或目录名进行处理,通常的操作是由路径中提取出文件名,从路径中提取出目录名,提取文件后缀名等等。例如,从路径/dir1/dir2/file.txt中提取也文件名file.txt,提取出目录/dir1/dir2,提取出文件后缀txt等。

下面介绍两种常用的方法来进行相关的操作。

一、使用 1 、 {} 1、 1{var##*/}
该命令的作用是去掉变量var从左边算起的最后一个’/‘字符及其左边的内容,返回从左边算起的最后一个’/’(不含该字符)的右边的内容。使用例子及结果如下:
在这里插入图片描述
从运行结果可以看到,使用该命令,可以提取出我们需要的文件名file.txt。

若使用时在shell程序文件中,可以使用变量来保存这个结果,再加以利用,如file=${var##*/}

2、${var##*.}
该命令的作用是去掉变量var从左边算起的最后一个’.‘字符及其左边的内容,返回从左边算起的最后一个’.’(不含该字符)的右边的内容。使用例子及结果如下:
在这里插入图片描述
从运行结果可以看到,使用该命令,可以提取出我们需要的文件后缀。

如果文件的后缀不仅有一个,例如,file.tar.gz,命令KaTeX parse error: Expected '}', got '#' at position 5: {var#̲#*.}仅能提取最后一个后缀,…{var#*.}命令了。

3、${var#*.}
该命令的作用是去掉变量var从左边算起的第一个’.‘字符及其左边的内容,返回从左边算起第一个’.’(不含该字符)的右边部分的内容。使用例子及结果如下:
在这里插入图片描述
从运行结果可以看到,使用该命令,可以提取出文件的多个后缀。

4、${var%/*}
该命令的使用是去掉变量var从右边算起的第一个’/‘字符及其右边的内容,返回从右边算起的第一个’/’(不含该字符)的左边的内容。使用例子及结果如下:
在这里插入图片描述
从运行的结果可以看到,使用该命令,可以提取出我们需要的文件所在的目录

5、${var%%.*}
该命令的使用是去掉变量var从右边算起的最后一个’.‘字符及其右边的内容,返回从右边算起的最后一个’.’(不含该字符)的左边的内容。使用例子及结果如下:
在这里插入图片描述
当我们需要建立一个与文件名相同名字(没有后缀)的目录与对应的文件相对应时,就可以使用该命令来进行操作。例如,解压文件的情况就与此类似,我们压缩文件file.zip时,会在与file.zip同级目录下建立一个名为file的目录。

6、 总 结 其 实 {}总结 其实 {}并不是专门为提取文件名或目录名的,它的使用是变量的提取和替换等等操作,它可以提取非常多的内容,并不一定是上面五个例子中的’/‘或’.’。也就是说,上面的使用方法只是它使用的一个特例。

看到上面的这些命令,可能会让人感到非常难以理解和记忆,其实不然,它们都是有规律的。

#:表示从左边算起第一个
%:表示从右边算起第一个
##:表示从左边算起最后一个
%%:表示从右边算起最后一个

换句话来说,#总是表示左边算起,%总是表示右边算起。

*:表示要删除的内容,对于#和##的情况,它位于指定的字符(例子中的’/‘和’.’)的左边,表于删除指定字符及其左边的内容;对于%和%%的情况,它位于指定的字符(例子中的’/‘和’.’)的右边,表示删除指定字符及其右边的内容。这里的’'的位置不能互换,即不能把号放在#或##的右边,反之亦然。

例如:${var%%x*}表示找出从右边算起最后一个字符x,并删除字符x及其右边的字符。

看到这里,就可以知道,其实该命令的用途非常广泛,上面只是指针文件名和目录名的命名特性来进行提取的一些特例而已。

二、basename和dirname
${}并不是专门为提取文件名和目录名设计的命令,那么basename和dirname命令就是专门为做这一件事而已准备的了。

1、basename
该命令的作用是从路径中提取出文件名,使用方法为basename NAME [SUFFIX]。

1)从路径中提出出文件名(带后缀),例子如下:
在这里插入图片描述
2)从上面命令的用法中可以看到,后缀(SUFFIX)是一个可选项。所以,若只想提取出文件名file,而不带有后缀,还可以在变量的后面加上后缀名,例子如下:
在这里插入图片描述
2、dirname
该命令的作用是从路径中提取出目录名,使用方法为 dirname NAME
使用例子如下:
在这里插入图片描述
这样就提取出了file.txt文件所在的目录。

注:该命令不仅能提取出普通文件所的目录,它能提取出任何文件所在的目录,例如目录所在的目录,如下:
在这里插入图片描述
它提取出了目录dir2所在的目录dir1.

参考博文:
https://blog.csdn.net/ljianhui/article/details/43128465

  • 3
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 很高兴为您服务!下面是一个bash脚本,用于将当前目录中的txt文件压缩成与文件名相同的zip压缩包: #!/bin/bashfor file in *.txt; do zip -j "${file%.*}".zip "$file" done ### 回答2: 下面是一个可以实现你所描述的功能的Linux shell脚本: ```shell #!/bin/bash # 遍历当前目录下的所有txt文件 for file in *.txt; do # 获取文件名(不包含扩展名) filename=$(basename "$file" .txt) # 创建对应的zip压缩包,并将txt文件添加到压缩包中 zip "$filename.zip" "$file" # 提示压缩完成 echo "已成功压缩$file到$filename.zip" done ``` 请将上述脚本保存为一个文件(如compress.sh),然后使用chmod命令给予执行权限: ```shell chmod +x compress.sh ``` 之后,在需要执行该脚本的目录下打开终端,并执行以下命令来运行脚本: ```shell ./compress.sh ``` 脚本会自动将该目录下的所有txt文件分别压缩成与txt文件名相同的zip压缩包,并输出相应的提示信息。 ### 回答3: 你好!下面是一个简单的Shell脚本,可以实现将当前目录下的所有txt文件分别压缩为与它们的文件名相同的zip压缩包: ```bash #!/bin/bash # 遍历当前目录下的所有txt文件 for file in *.txt; do # 提取文件名(不包括扩展名) filename=$(basename "$file" .txt) # 将txt文件压缩为zip文件(与文件名相同) zip "$filename.zip" "$file" # 打印处理的文件信息 echo "已压缩文件:$file --> $filename.zip" done ``` 请将以上代码保存为`compress.sh`文件,并在命令行中运行`bash compress.sh`命令,即可执行该脚本。执行脚本后,它将遍历当前目录下的所有txt文件,将每个txt文件压缩为与其文件名相同的zip压缩包,并打印出处理过程的信息。 希望这能帮到你!如果有任何问题,请随时提问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值