Linux高效编辑技巧:替换文本用awk和sed (linux awk sed替换)
在日常生活和工作中,我们经常需要对文件进行编辑和处理,其中最常见的操作就是替换文本。虽然在Linux下也有很多文本编辑器可以使用,但对于一些批量替换任务,传统的文本编辑器显然无法胜任。这时候,我们就需要使用awk和sed这两个工具来快速高效地完成替换任务。
一、awk的使用
1. 替换指定行的指定列
使用awk进行文本替换,可以轻松地定位到文件中的某一行的某一列,并替换成指定内容。下面是一个例子:
我们有一个文件test.txt,内容如下:
“`
apple,10,100
orange,15,200
banana,20,300
“`
如果我们需要将第2列的所有10替换成20,可以使用如下命令:
“`
awk -F”,” ‘{$2=gensub(/10/,”20″,1,$2)}1’ OFS=”,” test.txt
“`
解释一下上面的命令:
-F”,”:指定分隔符为逗号(,)
‘{ $2=gensub(/10/,”20″,1,$2) } 1’:这是awk的基本结构,包含3个部分:模式匹配块('{ }’),处理语句(’$2=gensub(/10/,”20″,1,$2)’})和条件语句(’1’)。模式匹配块表示针对每一行进行处理;然后,处理语句中的$2表示第2列,gensub函数用于替换匹配到的内容;条件语句1表示输出所有行,相当于省略了print语句。
OFS=”,”:指定输出分隔符为逗号(,)
test.txt:待处理的文件名
执行上述命令后,test.txt文件中的内容变成了:
“`
apple,20,100
orange,15,200
banana,20,300
“`
2. 针对所有行的指定列替换
如果需要对某一列的所有值进行替换,可以使用如下命令:
“`
awk -F”,” ‘{gsub(/10/,”20″,$2)}1’ OFS=”,” test.txt
“`
与前一个例子类似,不同之处在于使用了gsub函数,它表示全局替换。
3. 基于条件进行替换
除了替换指定列的值,我们也可以根据特定条件筛选出某些行,并对这些行中的特定列进行替换。比如,我们有一个file.txt文件,内容如下:
“`
A 123 B
C 456 D
A 789 E
C 012 F
A 345 G
“`
我们需要将第2列中所有大于等于500的数字替换成0。可以使用如下命令:
“`
awk ‘$2>=500{$2=0}1’ file.txt
“`
在这个命令中,我们使用了条件语句$2>=500表示筛选出所有第2列中大于等于500的数字,并把它们替换成0。
二、sed的使用
与awk相比,sed更加强调行处理,即对于每一行进行替换。下面是一些常见的sed命令:
1. 替换所有匹配的文本
“`
sed ‘s/old/new/g’ file.txt
“`
上面的命令中,s表示substitute(替换),old表示要被替换的文本,new表示替换后的新文本,g表示全局替换,即替换所有匹配的文本。
2. 指定行范围进行替换
“`
sed ‘1,3s/old/new/g’ file.txt
“`
上面的命令中,1,3表示需要处理的行的行号范围,s表示substitute(替换),old表示要被替换的文本,new表示替换后的新文本,g表示全局替换,即替换所有匹配的文本。
3. 在替换的行打印行号
“`
sed -n ‘/old/{s//&lineno:/p}’ file.txt
“`
上面的命令中,-n表示只显示匹配的文本,/old/表示需要匹配的文本,{s//&lineno:/p}中的s表示substitute(替换),&表示匹配的文本,lineno表示打印的行号,p表示打印所有匹配的行。
本文介绍了两个Linux下常用的文本处理工具——awk和sed,并分别给出了一些实用的替换命令。使用这些命令,我们可以在批量处理文本时提高效率和准确性,降低出错率。