我有一个如下所示的文件
1.2.3.4.ask
sanma.nam.sam
c.d.b.test
我想从每一行中删除最后一个字段,分隔符是.
并且字段数不是恒定的。
任何人都可以帮助我awk
或sed
找出解决方案。我不能perl
在这里使用。
这些sed
和awk
解决方案都与字段数量无关。
使用sed
:
$ sed -r 's/(.*)\..*/\1/' file
1.2.3.4
sanma.nam
c.d.b
注意:-r
是扩展正则表达式的标志,可以-E
用man sed
. 如果您的版本sed
没有此标志,则只需转义括号:
sed 's/\(.*\)\..*/\1/' file
1.2.3.4
sanma.nam
c.d.b
sed
解决方案是进行贪婪匹配直到最后一个并捕获它之前的.
所有内容,它只用匹配的部分(n-1
字段)替换整行。-i
如果您希望将更改存储回文件,请使用该选项。
使用awk
:
$ awk 'BEGIN{FS=OFS="."}{NF--; print}' file
1.2.3.4
sanma.nam
c.d.b
该awk
解决方案只是简单地打印n-1
字段,将更改存储回文件使用重定向:
$ awk 'BEGIN{FS=OFS="."}{NF--; print}' file > tmp && mv tmp file
倒车、剪车、倒车。
rev file | cut -d. -f2- | rev >newfile
或者,从最后一个点替换为什么都没有结束:
sed 's/\.[^.]*$//' file >newfile
正则表达式[^.]
匹配一个不是点(或换行符)的字符。您需要排除点,因为重复运算符*
是“贪婪的”;它将选择最左边,最长的匹配。
如果你想保留“。” 在下面使用:
awk '{gsub(/[^\.]*$/,"");print}' your_file
在cut
倒转的字符串上
cat youFile | rev |cut -d "." -f 2- | rev