java解析xml字符串 w3c_Java使用dom4j解析XML字符串

对于XML文件或者字符串的解析有很多方法。

1、较简洁的是W3C,实例如下:public void parseXmlByW3C(){

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

DocumentBuilder db;

Document doc = null;

try {

db = dbf.newDocumentBuilder();

InputStream inputStream = ClassLoader.getSystemResourceAsStream("interface.xml");

doc = db.parse(inputStream);

} catch (ParserConfigurationException e1) {

e1.printStackTrace();

} catch (SAXException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

NamedNodeMap nodes = doc.getElementsByTagName("Interface").item(0).getAttributes();

for(int i=0;i

System.out.println(nodes.item(i).getNodeName()+" : " +nodes.item(i).getNodeValue()+"\n");

}

NodeList nodeList = doc.getElementsByTagName("property");

for(int i=0;i

System.out.println(nodeList.item(i).getAttributes().item(0).getNodeValue()+":"+nodeList.item(i).getTextContent()+"\n");

}

}

2、使用Dom4j解析XML字符串:

import java.text.ParseException;

import java.util.HashMap;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import java.util.Map.Entry;

import java.util.concurrent.atomic.AtomicInteger;

import org.dom4j.Attribute;

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

public void parseXmlByDom4j(){

//需要解析的XML串

String strXml = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" +""+"test01" +"$ARG0"+"";

Map map = new HashMap();

Document doc = null;

try {

doc = DocumentHelper.parseText(strXml);

} catch (DocumentException e) {

//解析失败

e.printStackTrace();

}

if(doc==null)

return;

//获取跟节点

Element element = doc.getRootElement();

//获得根节点所有属性值

List> iList = element.attributes();

for(int i=0;i

Attribute attribute = (Attribute)iList.get(i);

map.put(attribute.getName(), attribute.getValue());

}

//遍历根节点下属性为property的子节点

Iterator> pIterator = element.elementIterator("property");

while(pIterator.hasNext()){

Element ele = (Element)pIterator.next();

//子节点的name的值,和Text

map.put(ele.valueOf("@name"), ele.getText());

}

//循环输出

Iterator> iterator = map.entrySet().iterator();

while(iterator.hasNext()){

Entry entry = iterator.next();

System.out.println(entry.getKey()+":"+entry.getValue());

}

}

在实际应用中,把W3C的解析方法放到Web工程中,总有解析错误,推荐使用Dom4j。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值