我想在制表符分隔文件的特定列中将“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()
如果您想在块中硬编码Fields
和Replacements
数组也是可能的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