首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用awk替换xml标记之间的多行文本。

用awk替换xml标记之间的多行文本。
EN

Stack Overflow用户
提问于 2018-04-29 15:26:33
回答 1查看 466关注 0票数 1

我有一个xml文件

代码语言:javascript
复制
`<private-keys>
    <private-key>
        <name>ssh_host_rsa_key</name>
    </private-key>
    <private-key>
        <name>test_server_pvt_key</name>
        <certificate-chains>
            <certificate-chain>
                <name>server_cert</name>
         <certificate>MIIECTCCAvGgAwIBAgIBCDANBgkqhkiG9w0BAQsFADCBjDELMAkGA1UEBhMCQ1ox
FjAUBgNVBAgMDVNvdXRoIE1vcmF2aWExDTALBgNVBAcMBEJybm8xDzANBgNVBAoM
...
J1t4nk9saeo87kIuNEDfYNdwYZzRfXoGJ5qIJQK+uJJv9noaIhfFowDW/G14Ji5p
Vh/YtvnOPh7aBjOj8jmzk8MqzK+TZgT7GWu48Nd/NaV8g/DNg9hlN047LaNsJly3
NX3+VBlpMnA4rKwl1OnmYSirIVh9RJqNwqe6k/k=</certificate>
            </certificate-chain>
        </certificate-chains>
    </private-key>
</private-keys>`

我正在尝试开发一个awk或sed,它可以将多行证书数据<certificate>...multi line data to be replace...</certificate>替换为另一个多行数据块,其结果如下:

代码语言:javascript
复制
`<private-keys>
    <private-key>
        <name>ssh_host_rsa_key</name>
    </private-key>
    <private-key>
        <name>test_server_pvt_key</name>
        <certificate-chains>
            <certificate-chain>
                <name>server_cert</name>
     <certificate>MIIEpAIBAAKCAQEAueCQaNQWoNmFK6LKu1p8U8ZWdWg/PvDdLsJyzfzl/Qw4UA68
SfFNaY06zZl8QB9W02nr5kWeeMY0VA3adrPgOlvfx3oWlFbkETnMaN4OT3WTQ0Wt
6jAWZDzVfopwpJPAzRPxACDftIqFGagYcF32hZlVNqqnVdbXh0S0EViweqp/dbG4
...
B4f09aeELM2ASIuk8Q/Mx0jQFnm8lzRFXdewgvdPoZW/7VufM9O7dGPOc41cm2Dh
yrTcXx/VmUBb+/fnXVEgCv7gylp/wtdTGHQBQJHR81jFBz0lnLj+gg==</certificate>
            </certificate-chain>
        </certificate-chains>
    </private-key>
</private-keys>`

我没有任何高级的正则表达式实用程序,可用的工具只有linux (甚至不是bash) awk和sed。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-29 15:53:32

代码语言:javascript
复制
$ cat tst.awk
NR==FNR {
    cert = (NR==1 ? "" : cert ORS) $0
    next
}
sub(/<certificate>.*/,"") {
    beg = $0 "<certificate>"
    inCert = 1
}
inCert {
    if ( sub(/.*<[\/]certificate>/,"") ) {
        end = "</certificate>" $0
        print beg cert end
        inCert = 0
    }
    next
}
{ print }

代码语言:javascript
复制
$ cat repl
MIIEpAIBAAKCAQEAueCQaNQWoNmFK6LKu1p8U8ZWdWg/PvDdLsJyzfzl/Qw4UA68
SfFNaY06zZl8QB9W02nr5kWeeMY0VA3adrPgOlvfx3oWlFbkETnMaN4OT3WTQ0Wt
6jAWZDzVfopwpJPAzRPxACDftIqFGagYcF32hZlVNqqnVdbXh0S0EViweqp/dbG4
...
B4f09aeELM2ASIuk8Q/Mx0jQFnm8lzRFXdewgvdPoZW/7VufM9O7dGPOc41cm2Dh
yrTcXx/VmUBb+/fnXVEgCv7gylp/wtdTGHQBQJHR81jFBz0lnLj+gg==

代码语言:javascript
复制
$ awk -f tst.awk repl file
<private-keys>
    <private-key>
        <name>ssh_host_rsa_key</name>
    </private-key>
    <private-key>
        <name>test_server_pvt_key</name>
        <certificate-chains>
            <certificate-chain>
                <name>server_cert</name>
         <certificate>MIIEpAIBAAKCAQEAueCQaNQWoNmFK6LKu1p8U8ZWdWg/PvDdLsJyzfzl/Qw4UA68
SfFNaY06zZl8QB9W02nr5kWeeMY0VA3adrPgOlvfx3oWlFbkETnMaN4OT3WTQ0Wt
6jAWZDzVfopwpJPAzRPxACDftIqFGagYcF32hZlVNqqnVdbXh0S0EViweqp/dbG4
...
B4f09aeELM2ASIuk8Q/Mx0jQFnm8lzRFXdewgvdPoZW/7VufM9O7dGPOc41cm2Dh
yrTcXx/VmUBb+/fnXVEgCv7gylp/wtdTGHQBQJHR81jFBz0lnLj+gg==</certificate>
            </certificate-chain>
        </certificate-chains>
    </private-key>
</private-keys>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50088255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档