awk没有选择字符串和管道作为分隔符

时间:2017-10-02 09:47:14

标签: linux awk pipe

我有一个文件,其中每个记录都有一个单词"TST_BI|",我需要用作分隔符并将此字符串后的值填充到文件中。每条记录中只出现一次此字符串。

使用以下命令在AIX环境中正常工作。 awk -F "TST_BI|" '{print $2}' file.txt

但是当我将代码迁移到Linux并尝试相同时,命令 NOT 正在运行,其中值"|"也会被填充。以下是AIX和Linux的输出

输入:

<14>1 2017-08-31T04:13:47.2345839+00:00 loggregator ecsdasc0985-cs656-4asdsds-asds-asdasg6ds73 [DEV/2] - - TST_BI|DATE~2017-08-31 04:13:47,095|TIMESTAMP~04:13:47|TEST_ID~biTestExecutor-2|COUNTRY_CODE~XX|GROUP_TESTS~BZAG
来自AIX的

OutPut:

DATE~2017-08-31 04:13:47,095|TIMESTAMP~04:13:47|TEST_ID~biTestExecutor-2|COUNTRY_CODE~XX|GROUP_TESTS~BZAG

使用相同的命令, Linux输出

|DATE~2017-08-31 04:13:47,095|TIMESTAMP~04:13:47|TEST_ID~biTestExecutor-2|COUNTRY_CODE~XX|GROUP_TESTS~BZAG

管道正在填充,而不是作为分隔符处理。

有人可以帮忙吗?

1 个答案:

答案 0 :(得分:3)

使用相邻字符指定的竖线条|被视为正则表达式交替运算符/替换组。在这种情况下,要按字面意思对待|,应将其转义\\|或放入字符类[|]

awk -F'TST_BI[|]' '{print $2}' file.txt

输出:

DATE~2017-08-31 04:13:47,095|TIMESTAMP~04:13:47|TEST_ID~biTestExecutor-2|COUNTRY_CODE~XX|GROUP_TESTS~BZAG