zoukankan      html  css  js  c++  java
  • java 解析 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) {
            //创建一个新的字符串
            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);
        }
    }

    戒骄戒躁,一步一个脚印
  • 相关阅读:
    SQL语句获取数据库名、表名、储存过程以及参数列表 狼
    CKEditor3.3+CKFinder2.0附带CKF去除水印 狼
    media player 和realplayer 编程接口 狼
    教您如何去认识人!(识人术) 狼
    引用 JS判断浏览器类型方法 狼
    (转)初始化多维数组
    kmeans 聚类 (代码为: 博客数据聚类) (python )
    对博客订阅源URL中的单词进行计数 (仅限英文博客,中文订阅源不支持 )
    eclipse +python 修改 各种颜色 +字体
    常见错误收集: lucene 读取word文档问题
  • 原文地址:https://www.cnblogs.com/sophelia-M/p/4058831.html
Copyright © 2011-2022 走看看