[英]Exclude characters using awk
我正在尝试找到一种方法在排除ti时排除文件中的数字,但我只想排除打印$ 1上的数字,并且我想保留单词前面的数字。 我有一些我认为可能会起作用的东西,但并没有完全满足我的需求。 我还展示了一个文件外观示例,该文件由管道分隔。
cat files | awk -F '|' ' {print $1 "\t" $2}' |sed 's/0123456789//g'
输入:
b1ark45 | dog23 | brown
m2eow66| cat24 |yellow
h3iss67 | snake57 | green
输出量
b1ark dog23
m2eow cat24
h3iss nake57
尝试这个:
awk -F'|' -v OFS='|' '{gsub(/[0-9]/,"",$1)}7' file
您的示例的输出为:
bark | dog23 | brown
meow| cat24 |yellow
hiss | snake57 | green
编辑
这将输出col1(没有结尾数字和空格)和col2,以<tab>
分隔
kent$ echo "b1ark45 | dog23 | brown
m2eow66| cat24 |yellow
h3iss67 | snake57 | green"|awk -F'|' -v OFS='\t' '{gsub(/[0-9]*\s*$/,"",$1);print $1,$2}'
b1ark dog23
m2eow cat24
h3iss snake57
这可能对您有用(GNU sed):
sed -r 's/[0-9]*\s*\|\s*(\S*).*/ \1/' file
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.