Awk 如果一个字符串在特定文件中最后一行的开头匹配,则替换同一行中的另一个字符串。是否使用正则表达式组?

Awk 如果一个字符串在特定文件中最后一行的开头匹配,则替换同一行中的另一个字符串。是否使用正则表达式组?,awk,sed,Awk,Sed,我有一个文件“测试” 以下是内容 235788@@@235788@@@20200724_103122@@@SUCCESS 235791@@@235791@@@20200724_105934@@@SUCCESS 235833@@@235833@@@20200724_130652@@@FAILURE 235842@@@235842@@@20200724_132721@@@FAILURE 235852@@@235852@@@20200724_134607@@@FAILURE 235791@@@2357

我有一个文件“测试”

以下是内容

235788@@@235788@@@20200724_103122@@@SUCCESS
235791@@@235791@@@20200724_105934@@@SUCCESS
235833@@@235833@@@20200724_130652@@@FAILURE
235842@@@235842@@@20200724_132721@@@FAILURE
235852@@@235852@@@20200724_134607@@@FAILURE
235791@@@235791@@@20200724_105934@@@SUCCESS
如果此文件的最后一行以235791开头,则将该行上的字符串“SUCCESS”替换为“FAILURE”

预期产量

235788@@@235788@@@20200724_103122@@@SUCCESS
235791@@@235791@@@20200724_105934@@@SUCCESS
235833@@@235833@@@20200724_130652@@@FAILURE
235842@@@235842@@@20200724_132721@@@FAILURE
235852@@@235852@@@20200724_134607@@@FAILURE
235791@@@235791@@@20200724_105934@@@FAILURE
下面是示例代码

id = 235791
last_build_id  = `tail -1 test | awk -F'@@@' '{print \$1}'`
if (id == last_build_id  ){
    sed -i '$s/SUCCESS/FAILURE/' test
}

我希望避免使用这么多行,而使用一行shell命令使用正则表达式组或任何其他简单的方式。

请您尝试使用GNU
awk
中显示的示例编写并测试以下命令。您不需要为这一个使用许多命令,我们可以在单个
awk
本身中完成这一操作

代码的一种线性形式:

awk-v id=“$your_shell_variable”'BEGIN{FS=OFS=“@@@NR>1{print prev}{prev=$0}END{if($1==id&&$NF==“SUCCESS”){$NF=“FAILURE”};print}输入文件>临时和临时输入文件

说明:添加上述内容的详细说明

awk -v id="$your_shell_variable"'                                     ##Starting awk program from here.
NR>1{                                     ##Checking condition if prev is NOT NULL then do following.
  print prev                              ##Printing prev here.
}
{
  prev=$0                                 ##Assigning current line to prev here.
}
END{                                      ##Starting END block of this program from here.
  if($1==id && $NF=="SUCCESS"){       ##Checking condition if first field is 235791 and last field is SUCCESS then do following.
    $NF="FAILURE"                         ##Setting last field FAILURE here.
  }
  print                                   ##Printing last line here.
}
'  Input_file > temp && mv temp Input_file                           ##Mentioning Input_file name here.


第二种解决方案:根据Ed sir的评论,一些
awk
不支持
$1
$NF
结束
部分,因此如果上述解决方案对某人不起作用,请尝试以下更通用的解决方案

一种线性形式的解决方案(因为特别要求):

awk-v id=“$your_shell_variable”'BEGIN{FS=OFS=“@@@@NR>1{print prev}{prev=$0}END{num=split(prev,array,@@@@@@@”);if(array[1]=id&&array[num]=SUCCESS”){array[num]=FAILURE};for(i=1;i1){
打印上一页
}
{
上一期=$0
}
结束{
num=split(上一个,数组“@@@”)
if(数组[1]==id&&array[num]==SUCCESS){
数组[num]=“失败”
}

对于(i=1;i
sed
在这里可能更容易

$ sed -E '$s/(^235791@.*)SUCCESS$/\1FAILURE/' file
您可以为就地更新添加
-i

将id作为变量传递

$ id=235791; sed -E '$s/(^'$id'@.*)SUCCESS$/\1FAILURE/' file
理想情况下,您应该双引号引用“$id”
,但如果您确定内容,您可能不需要它。

使用GNU

$ awk -v val='235791' '
    BEGIN { FS=OFS="@@@" }
    NR>1 { print prev }
    { prev=$0 }
    END {
        $0=prev
        if ($1 == val) {
            $NF="FAILURE"
        }
        print
    }
' file
235788@@@235788@@@20200724_103122@@@SUCCESS
235791@@@235791@@@20200724_105934@@@SUCCESS
235833@@@235833@@@20200724_130652@@@FAILURE
235842@@@235842@@@20200724_132721@@@FAILURE
235852@@@235852@@@20200724_134607@@@FAILURE
235791@@@235791@@@20200724_105934@@@FAILURE
sed-E'${/^235791\>/s/SUCCESS$/FAILURE/}文件
或者在MacOS上使用BSD

sed-E'${/^235791@/s/SUCCESS$/FAILURE/;}文件

使用“文件中的最后一个X”时,通常更容易反转文件并使用“第一个X”:

tac文件| awk'
开始{FS=OFS=“@@@1}
NR==1&&$1==235791&&$NF==“成功”{$NF=“失败”}
1.
|交谘会

我应该如何为235791使用变量。我不能使用双引号,我需要将其放在groovy代码中。@Bhargav请查看更新,不确定为什么不能使用双引号,但这可以避免对给定的输入类型使用双引号。–在groovy脚本中,我需要使用类似于sh“sed-I'$s/SUCCESS/FAILURE/”test的内容这是在If条件原始post中验证后的一行。我不擅长sed。在失败之前可能知道什么是1,如果(id==last_build_id),该命令是否按照我的要求进行验证当然,在我最初的帖子?@Bhargav中,只有当有匹配的
\1
将捕获组1放回输出中(括号中的部分)时,才会发生替换。但是,不要相信这些注释并进行测试。
$ awk -v val='235791' '
    BEGIN { FS=OFS="@@@" }
    NR>1 { print prev }
    { prev=$0 }
    END {
        $0=prev
        if ($1 == val) {
            $NF="FAILURE"
        }
        print
    }
' file
235788@@@235788@@@20200724_103122@@@SUCCESS
235791@@@235791@@@20200724_105934@@@SUCCESS
235833@@@235833@@@20200724_130652@@@FAILURE
235842@@@235842@@@20200724_132721@@@FAILURE
235852@@@235852@@@20200724_134607@@@FAILURE
235791@@@235791@@@20200724_105934@@@FAILURE