大家好,又见面了,我是你们的朋友全栈君。
这里写到两种xml解析方法。分别针对字符串类型的xml和文件类型的xml。
第一种:对xml字符串进行解析
import java.io.IOException;
import java.io.StringReader;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.Namespace;
import org.jdom.input.SAXBuilder;
import org.xml.sax.InputSource;
public class DuXMLDoc {
public List xmlElements(String xmlDoc) {
if (xmlDoc!=null && !xmlDoc.equals("")) {
Pattern p = Pattern.compile("\r|\n");
Matcher m = p.matcher(xmlDoc);
xmlDoc = m.replaceAll("");
}//创建一个新的字符串
StringReader read = new StringReader(xmlDoc);
//创建新的输入源SAX 解析器将使用 InputSource 对象来确定如何读取 XML 输入
InputSource source = new InputSource(read);
//创建一个新的SAXBuilder
SAXBuilder sb = new SAXBuilder();
try {
//通过输入源构造一个Document
Document doc = sb.build(source);
//取的根元素
Element root = doc.getRootElement();
System.out.println(root.getName());//输出根元素的名称(测试)
//得到根元素所有子元素的集合
List jiedian = root.getChildren();
//获得XML中的命名空间(XML中未定义可不写)
Namespace ns = root.getNamespace();
Element et = null;
for(int i=0;i<jiedian.size();i++){
et = (Element) jiedian.get(i);//循环依次得到子元素
System.out.println(et.getChild("users_id",ns).getText());
System.out.println(et.getChild("users_address",ns).getText());
}
et = (Element) jiedian.get(0);
List zjiedian = et.getChildren();
for(int j=0;j<zjiedian.size();j++){
Element xet = (Element) zjiedian.get(j);
System.out.println(xet.getName());
}
} catch (JDOMException e) {
// TODO 自动生成 catch 块
e.printStackTrace();
} catch (IOException e) {
// TODO 自动生成 catch 块
e.printStackTrace();
}
return null;
}
public static void main(String[] args){
DuXMLDoc doc = new DuXMLDoc();
String xml = "<?xml version=\"1.0\" encoding=\"gb2312\"?>"+
"<Result xmlns=\"http://www.fiorano.com/fesb/activity/DBQueryOnInput2/Out\">"+
"<row resultcount=\"1\">"+
"<users_id>1001 </users_id>"+
"<users_name>wangwei </users_name>"+
"<users_group>80 </users_group>"+
"<users_address>1001号 </users_address>"+
"</row>"+
"<row resultcount=\"1\">"+
"<users_id>1002 </users_id>"+
"<users_name>wangwei </users_name>"+
"<users_group>80 </users_group>"+
"<users_address>1002号 </users_address>"+
"</row>"+
"</Result>";
doc.xmlElements(xml);
}
}
}
第二种:对xml文件进行解析
package com.zuidaima.xml;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
/*******************************************************************************
* xml通用工具类
* @author www.zuidaima.com
*/
@SuppressWarnings("unchecked")
public class XMLUtils
{
public static String xml = "";
public static void init()
{
xml = "";
}
/***************************************************************************
* 得到指定名称节点下的所有文本内容,包括节点(逆归) <暂不考虑节点属性情况>
*
* @param doc
* xml文档对象
* @param e
* 要获取的节点对象
* @param exceptTag
* 要排除的节点名称
* @return
*/
public static String getChildAllText(Document doc, Element e)
{
if (e != null)
{
if (e.getChildren() != null)
{
List<Element> list = e.getChildren();
xml += "<" + e.getName() + ">";
for (Element el : list)
{
if(el.getChildren().size() > 0)
{
getChildAllText(doc, el);
}
else
{
xml += "<" + el.getName() + ">" + el.getTextTrim() + "</"
+ el.getName() + ">";
}
}
xml += "</" + e.getName() + ">" ;
}
else
{
xml += "<" + e.getName() + ">" + e.getTextTrim() + "</"
+ e.getName() + ">";
}
}
return xml;
}
public static void main(String[] args) throws FileNotFoundException,
JDOMException, IOException
{ // 如果有任何异常则抛出
SAXBuilder sb = new SAXBuilder(); // 新建立构造器
Document doc = null;
doc = sb
.build(new FileInputStream(
"D:\\test.xml")); // 读入6.xml
Element root = doc.getRootElement(); // 取得根节点
// Element e = root.getChild("apptype1");
// System.out.println(e);
System.out.println(getChildAllText(doc, root));
}
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/140692.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...