大佬教程收集整理的这篇文章主要介绍了如何在 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;
但我无法将我的字段分开,我将整个记录作为输出。
这样做的正确方法是什么?
您可以使用:
awk -F '\\^@' '{print $2}' file
343453
说明:
^
是特殊的正则表达式元字符,需要双重转义,而 @
不需要任何转义。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
以上是大佬教程为你收集整理的如何在 AWK 中将字段分隔符设置为 ^@(特殊字符)?全部内容,希望文章能够帮你解决如何在 AWK 中将字段分隔符设置为 ^@(特殊字符)?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。