繁体   English   中英

如何在 AWK 中将字段分隔符设置为 ^@(特殊字符)?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM