您好,提前感谢您的回答。
当我使用以下代码时,我得到如下输出:
/home/pony/IOSO/test/A
/home/pony/IOSO/test/B
FILE=last.cfg
DIR=$(realpath "$2") #or something else
grep $DIR $FILE | awk '{ print $2 }' | sort | uniq # | basename does not work
如何让我的管道使用基本名称或类似的名称:
$ s=/the/path/foo.txt
$ echo ${s##*/}
foo.txt
最佳答案
您可以使用 awk
来完成此操作,这样就可以避免不必要地使用 grep
awk
和 sed
序列
正确的方法可以是
awk -v dir="$DIR" -F"/" '$0 ~ dir{print $NF}'
测试
$ DIR="/home/pony/IOSO/test"
$ cat input
/home/pony/IOSO/test/A
/home/pony/IOSO/test/B
/home/test/test
$ awk -v dir="$DIR" -F"/" '$0 ~ dir{print $NF}' input
A
B
它的作用
-v dir="$DIR"
使用 shell 变量DIR
的值创建一个awk
变量-F"/"
将字段分隔符设置为/
。这是在输入文件中完成的,目录由/
分隔,我们需要获取最后一个字段,文件名。'$0 ~ dir
检查每个输入行是否与变量dir
中的模式匹配print $NF
打印最后一个字段,这里是文件名。NF
代表字段数。
关于linux - 使用管道时类似于字符串操作的基本名称,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29641927/