[英]How to set field separator as ^@ (special characters) in AWK?
我有这种格式的记录。
^@343453^@145562998^@1001^@1KDI03K^@1802282^@10^@118543r221^@10^@1k2FOOD^@1NB^@1^@4554545^@3444545^@1STD^@45454554^@1NORMAL^@1^@1^@1^@1CDIH^@1^@12PY567
这里的字段分隔符是^@,文件共有73个字段
我努力了
awk -F "^@" ' { print $1} ' file.txt;
awk -F "\^\@" ' { print $1} ' file.txt;
但是我无法将我的字段分开我将整个记录作为 output。
这样做的正确方法是什么?
您可以使用:
awk -F '\\^@' '{print $2}' file
343453
解释:
^
是特殊的正则表达式元字符,需要双重转义,而@
不需要任何 escaping。print $2
而不是print $1
因为您在记录开头有分隔符^@
因此$1
或第一个字段将为空。 您需要在字段分隔符中加倍转义^
。 为什么需要转义它,因为它具有特殊含义,因此要使其被视为文字字符,请使用此字符。
awk -F'\\^@' '{print $2}' Input_file
您的第一个字段是空的,因此无法打印,因此要了解您的字段编号及其显示示例的值,您可以尝试以下命令以更好地理解它们。
awk -F'\\^@' '{for(i=1;i<=NF;i++){print "field Number:"i " field value is:" $i}}' Input_file
您的样本的几行将是:
field Number:1 field value is:
field Number:2 field value is:343453
field Number:3 field value is:145562998
field Number:4 field value is:1001
field Number:5 field value is:1KDI03K
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.