xml - 用 awk/sed 替换 XML 文件中的字符串和另一个文件中的字符串

标签 xml linux awk sed

抱歉,标题太长/太奇怪了,但我遇到了一个问题。我有这个 XML 文件:

</member>
     <member>
      <name>TransactionID</name>
      <value><string>123456789123456</string></value>
     </member>
     <member>
      <name>Number</name>
      <value><string>765101293</string></value>
     </member>

在那里,我必须用另一个文件 file2 中的另一个值替换“765101293”:

765003448
765885388
764034143
784478101
762568592
769765134
767200702
769550613
784914007
762333840

因此,XML 文件将在 file2 中的每个新字符串处发生变化。我不知道该怎么做。我正在考虑先用 awk 处理 file2,然后再将管道送入 sed:

代码:

#! /bin/bash -f

var=`awk -F,"\n" '{print $0}' "$1"`
sed -i "/7[0-9]{8}/c\$var/" "$2"

所以,我想用 file2 中的数据更新我的 XML 文件 (Update.xml)。对于 file2 的第一行,我必须更新现有的 XML:我将 file2 的第一行 > 765003448 代替“765101293”。然后我将把 xml 移到其他地方,然后传递给file2 的下一行。对 file2 的所有行重复该过程。我在运行脚本时使用的两个变量 $1 和 $2:./script.sh file2 Update.xml。

谁能帮帮我?

编辑:

这是我的完整 xml 文件:

<methodCall>
 <methodName>UpdateOffer</methodName>
 <params>
  <param>
   <value>
    <struct>
     <member>
      <name>offerID</name>
      <value><i4>19</i4></value>
     </member>
     <member>
<name>startDate</name>
<value><dateTime.iso8601>20151028T14:11:00+0200</dateTime.iso8601></value>
</member>
     <member>
      <name>offerType</name>
      <value><i4>0</i4></value>
     </member>
     <member>
      <name>originHostName</name>
      <value><string>TEST</string></value>
     </member>
     <member>
      <name>originNodeType</name>
      <value><string>Prepaid</string></value>
     </member>
     <member>
      <name>originOperatorID</name>
      <value><string>operator</string></value>
     </member>
<member><name>originTimeStamp</name>
<value><dateTime.iso8601>20151028T14:16:36+0200</dateTime.iso8601></value>
</member>
     <member>
      <name>originTransactionID</name>
      <value><string>123456789123456</string></value>
     </member>
     <member>
      <name>subscriberNumber</name>
      <value><string>765101293</string></value>
     </member>
    </struct>
   </value>
  </param>
 </params>
</methodCall>

最佳答案

听起来您只需要:

awk 'NR==FNR{nums[NR]=$0;next} sub(/>7[0-9]{8}</,">"nums[i+1]"<"){i++}' file2 Update.xml

但鉴于您问题中的小示例 XML 文件输入/输出,很难猜测。

请记住这一点:

  1. 每次您在 shell 中编写循环来处理文本时,您的方法都是错误的。参见 https://unix.stackexchange.com/questions/169716/why-is-using-a-shell-loop-to-process-text-considered-bad-practice .
  2. shell 是一种环境,可以从中操作文件和进程,并对工具调用进行排序。处理文本的 UNIX 工具是 awk。阅读 Arnold Robbins 撰写的 Effective Awk Programming,第 4 版。

关于xml - 用 awk/sed 替换 XML 文件中的字符串和另一个文件中的字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35359144/

相关文章:

java - 当我向布局 xml 文件添加按钮时,Android 应用程序崩溃

c++ - 无法访问 argv[0],如何获取程序名称?

python - 使用python设置环境变量

php - 允许脚本读取文件但阻止用户直接查看文件

linux - 从文本文件中获取特定字符串

arrays - 通过匹配与 awk 合并文件 - awk 不打印所有数组分配

regex - sed 插入/追加和打印模式空间

xml - Scala:处理可选的 XML 元素和 Case 类

jquery - Jquery 中的 XML 解析

c++ - 如果从文件流读取数据,为什么 gSOAP 将标准输入模式设置为二进制?