0

我在文本文件中有这些数据。需要转换以放入模板

数据.txt

*   A   11.22.33.44
mail    A   11.22.33.44
domain1.com     A   11.22.33.44
ftp     CNAME   domain1.com
www     CNAME   domain1.com
domain1.com MX mail.domain1.com

*   A   55.66.77.88
mail    A   55.66.77.88
domain2.com     A   55.66.77.88
ftp     CNAME   domain2.com
www     CNAME   domain2.com
domain2.com MX mail.domain2.com

通过这个vim命令运行它

:g/NS/d | :%s/CNAME/cnamerecord/g | :%s/A/arecord/g | :%s/MX/mxrecord/g

将其更改为:

arecord *                11.22.33.44
arecord mail             11.22.33.44
arecord domain1.com      11.22.33.44
ftp     cnamerecord     domain1.com
www     cnamerecord     domain1.com
domain1.com mxrecord mail.domain1.com

arecord *         55.66.77.88
arecord mail             55.66.77.88
arecord domain2.com             55.66.77.88
ftp     cnamerecord     domain2.com
www     cnamerecord     domain2.com
domain2.com mxrecord mail.domain2.com

现在我运行一个 AWK 命令

cat data.txt |
awk '{if ($2 == "arecord") print $2 " " $1 " " $3}
     {if ($2 == "cnamerecord") print $2 " " $1 "." $3 " " $3}
     {if ($2 == "mxrecord") print $2 " " $1 " " $3}'

输出如下:

arecord * 11.22.33.44
arecord mail 11.22.33.44
arecord domain1.com 11.22.33.44
cnamerecord ftp.domain1.com domain1.com
cnamerecord www.domain1.com domain1.com
mxrecord domain1.com mail.domain1.com
arecord * 55.66.77.88
arecord mail 55.66.77.88
arecord domain2.com 55.66.77.88
cnamerecord ftp.domain2.com domain2.com
cnamerecord www.domain2.com domain2.com
mxrecord domain2.com mail.domain2.com

现在,这里有两个问题:

问题 1 和我最头疼的问题:如何保持数据之间的空间。我想保留的文件中有一个空行。

问题 #2(加分):在我的 AWK 代码中,我希望 arecord 显示为:

arecord *.domain1.com 55.66.77.88
arecord mail.domain1.com 55.66.77.88
arecord domain1 55.66.77.88

不是:

arecord * 11.22.33.44
arecord mail 11.22.33.44
arecord domain1.com 11.22.33.44

最终的理想输出看起来像这样

arecord *.domain1.com 11.22.33.44
arecord mail.domain1.com 11.22.33.44
arecord domain1.com 11.22.33.44
cnamerecord ftp.domain1.com domain1.com
cnamerecord www.domain1.com domain1.com
mxrecord domain1.com mail.domain1.com

arecord *.domain2.com 55.66.77.88
arecord mail.domain2.com 55.66.77.88
arecord domain2.com 55.66.77.88
cnamerecord ftp.domain2.com domain2.com
cnamerecord www.domain2.com domain2.com
mxrecord domain2.com mail.domain2.com

我必须为 150 个域执行此操作

任何帮助都会很棒

4

2 回答 2

2

如果将单独的if语句加入到 中if..else if..else,则可以添加回退以按原样打印所有其他行;这将保留空行(以及任何注释行等):

cat data.txt | awk '{if ($2 == "arecord") print $2 " " $1 " " $3; else if ($2 == "cnamerecord") print $2 " " $1 "." $3 " " $3; else if ($2 == "mxrecord") print $2 " " $1 " " $3; else print}'
于 2013-09-26T07:00:58.593 回答
2

有的这样?

cat file
arecord * 11.22.33.44
arecord mail 11.22.33.44
arecord domain1.com 11.22.33.44
ftp cnamerecord domain1.com
www cnamerecord domain1.com
domain1.com mxrecord mail.domain1.com

arecord * 55.66.77.88
arecord mail 55.66.77.88
arecord domain2.com 55.66.77.88
ftp cnamerecord domain2.com
www cnamerecord domain2.com
domain2.com mxrecord mail.domain2.com

awk 命令

awk '
/arecord/ && !c { 
    c=NR+2}
NR==c {
    c=0
    print $1 " *." $2,$3 "\n" $1" mail." $2,$3 "\n" $0}
/^ftp|^www/{
    print $2,$1 "." $3,$3}
/mxrecord/ {
    print $2,$1,$3}
!NF {
    print ""}
' file
arecord *.domain1.com 11.22.33.44
arecord mail.domain1.com 11.22.33.44
arecord domain1.com 11.22.33.44
cnamerecord ftp.domain1.com domain1.com
cnamerecord www.domain1.com domain1.com
mxrecord domain1.com mail.domain1.com

arecord *.domain2.com 55.66.77.88
arecord mail.domain2.com 55.66.77.88
arecord domain2.com 55.66.77.88
cnamerecord ftp.domain2.com domain2.com
cnamerecord www.domain2.com domain2.com
mxrecord domain2.com mail.domain2.com

更新以摆脱getline

于 2013-09-26T06:44:59.920 回答