[英]how to print tail of path filename using awk
我搜索它没有成功。
我有一个带有pathes的文件。 我想要打印所有路径的尾部。 例如(对于文件中的每一行):
/homes/work/abc.txt
--> abc.txt
有谁知道怎么做?
谢谢
awk -F "/" '{print $NF}' input.txt
将给出的输出:
abc1.txt
abc2.txt
abc3.txt
对于:
$>cat input.txt
text path/to/file/abc1.txt
path/to/file/abc2.txt
path/to/file/abc3.txt
这个awk
怎么样?
echo "/homes/work/abc.txt" | awk '{sub(/.*\//,x)}1'
abc.txt
由于.*
是贪婪的,它会一直持续到最后/
所以在这里我们删除所有直到最后/
用x
,因为x
是空的,什么都不给。
Thors版本
echo "/homes/work/abc.txt" | awk -F/ '$0=$NF'
abc.txt
注意这对于/homes/work/0
或0,0
等都会失败,所以更好用:
echo "/homes/work/abc.txt" | awk -F/ '{$0=$NF}1'
awk
解决方案已由@Jotne和@bashophil提供
这里有一些其他的变化(只是为了好玩)
使用sed
sed 's:.*/::' file
使用grep
grep -oP '(.*/)?\K.*' file
使用cut
- 由@Thor添加
rev file | cut -d/ -f1 | rev
使用basename
- 由@fedorqui和@EdMorton建议
while IFS= read -r line; do
basename "$line"
done < file
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.