将特定列中的一个测试字符串替换为另一个测试字符串

将特定列中的一个测试字符串替换为另一个测试字符串

我想在制表符分隔文件的特定列中将“CC”替换为“C”,将“AA”替换为A”(awk可能使用)。

答案1

awk -F'\t' -vOFS='\t' '{ gsub("CC", "C", $1) ; gsub("AA", "A", $1) ; print }'

替换$1为您要修改的列。

答案2

如果您无权访问gsub(),但您确实可以访问split(),则可以这样创建等效项:

给定输入

AA      AA      CC      CC      AA      CC

以下awk脚本

BEGIN {
    OFS = "\t";
    split("1 3 5", Fields);
    split("A C", Replacements);
}
{
    for (i in Fields) {
        for (j in Replacements) {
            Replace = Replacements[j];
            sub(Replace Replace, Replace, $Fields[i]);
        }
    }
    print;
}

将为字段 1、3 和 5 生成所需的结果:

A       AA      C       CC      A       CC

即使没有,split()如果您想在块中硬编码FieldsReplacements数组也是可能的BEGIN

答案3

要在一个字段中查找和替换,请使用以下命令:

sed 's/whatyouwanttofind/whatyouwanttoreplace/field#'

即你回应这个:

$echo -e "1are,2are,3are,4are\n5are,6are,7are,8are"

1are,2are,3are,4are

5are,6are,7are,8are

你想要这样做

$echo -e "1are,2are,3are,4are\n5are,6are,7are,8are" |  sed 's/are/arrr/2'

1are,2**arrr**,3are,4are

5are,6**arrr**,7are,8are

相关内容