我有一个非常简单的 grep 问题,但似乎无法解决。我有几个这样的文件:
sample.txt
sample7.doc.txt
another_sample.sample.lst.txt
three.txt
...而且我只想抓住“.txt”之前的所有内容。我试图在这样的 shell 脚本中执行此操作:
ame=`echo $1 | grep -Po "^[A-Za-z0-9]+"`
...但当然,这只会返回第一个“点”之前的部分。有人可以帮忙修改这个正则表达式吗?
不需要正则表达式:
$ basename sample.txt .txt
sample
或使用任何与 POSIX 兼容的外壳:
$ echo "$a"
sample.txt
$ y=${a%.txt}
$ echo "$y"
sample
试试这个:
grep -Po '.*(?=\.txt$)'
删除 .txt
名称=echo $1|sed 's/.txt$//'
使用基本名称
名称=echo $fullname|basename .txt
mv $1 $(echo $1 | awk -F.txt '{print $1}')