linux Shell Sed 命令 -- 如何 处理 XML 文件

linux Shell Sed 命令 -- 如何 处理 XML 文件,第1张

1、思路,sed可以删除指定行内容,也可以在指定行添加内容

2、首先确定BB.Name所在行,如果有重复,需要增加head -1

r1=`grep -n "BB.Name" a.xml|awk -F: '{print $1}'|head -1`

3、<property>行号r2

((r2=r1-1))

4、</property>行号r3

((r3=r1+3))

5、删除r2和r3中间所有行

sed -i '${r2},${r3}d' a.xml

sed -i '5,8d' a.xml

sed -i '5d' a.xml

6、在r4行处读入s.txt内容

((r4=r1-2))

sed -i '$r4 r s.txt' a.xml

7、实例

#!/bin/sh

r1=`grep -n "BB.Name" a.xml|awk -F: '{print $1}'|head -1`

((r2=r1-1))

((r3=r1+3))

((r4=r1-2))

sed -i "${r2},${r3}d" a.xml

sed -i "${r4} r s.txt" a.xml

sed -nr '/task id/{s/.*<task id="([^"]+)"\sbusiness="([^"]+)".*/\1,\2/p}' test.xml

或者:

awk '/task id/{split($0,a,"(=\")|(\" )")print a[2]","a[4]}' test.xml

或者:

sed -n '/task id/{s/"//gs/^ *//p}' test.xml | awk -F"[= ]" '{print $3","$5}'

1. JS加载XML文件

步骤一般为(1),建立 XML DOM 对象;(2),设置加载方式,异步(推荐)或同步; (3)提供XML文件URL然后调用 load 方法;大致如下:

var xmlFileName="xxFile.xml"

var xmlDoc=''

if (window.ActiveXObject){ // IE

var activeXNameList=new Array("MSXML2.DOMDocument.6.0","MSXML2.DOMDocument.5.0","MSXML2.DOMDocument.4.0","MSXML2.DOMDocument.3.0","MSXML2.DOMDocument","Microsoft.XMLDOM","MSXML.DOMDocument")

for(var h=0h

{

try{

xmlDoc=new ActiveXObject(activeXNameList[h])

}catch(e){

continue

}

if(xmlDoc) break

}

}else if(document.implementation &&document.implementation.createDocument){ //非 IE

xmlDoc=document.implementation.createDocument("","",null)

}else{

alert('can not create XML DOM object, update your browser please...')

}

xmlDoc.async=false//同步,防止后面程序处理时遇到文件还没加载完成出现的错误,故同步等XML文件加载完再做后面处理

xmlDoc.load(xmlFileName)//加载XML

2. JS读取XML文件节点

在加载XML文件之后就是读取XML文件的节点了,可以使用 DOM 相应的方法,对 MS IE 其它浏览器的读法相近,例如:

例如下的XML文件结构:

shenzhen

shenzhenNBA

man

shenzhen

xiaoming

woman

zhangsan

man

//JS读取 XML 文件中的 area 节点的方式如下:

var nodeList= xmlDoc.documentElement.getElementsByTagName("area"); // IE

for(var i=0i

//...遍历 *** 作...

}

var nodeList=xmlDoc.getElementsByTagName("area")// 非IE

for(var i=0i

//...遍历 *** 作...

}

还有部分读取节点的方法:

//MS IE

node.text //读取node节点的文本值

node.childNodes[i].text //读取 node 下的第 i 个[直接下一级]子节点的文本

node.getAttribute("attributeName") //读取 node 节点的属性名称为 attributeName 的属性值

//还有其他的方法等, 可以网上搜索


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7461520.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-05
下一篇2023-04-05

发表评论

登录后才能评论

评论列表(0条)

    保存