论坛首页 入门技术论坛

JDOM解析XML字符串(非XML文档)

浏览 6875 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (6)
作者 正文
   发表时间:2010-02-22   最后修改:2010-02-24
package com.tyyz;

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);//循环依次得到子元素
                /**//*
                 * 无命名空间定义时
                 * et.getChild("users_id").getText();
                 * et.getChild("users_address",ns).getText()
                 */
                System.out.println(et.getChild("users_id",ns).getText());
                System.out.println(et.getChild("users_address",ns).getText());
            }
            /**//*
             * 如要取<row>下的子元素的名称
             */
            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);
    }
}
   发表时间:2010-02-23  
不管是文档还是字符串,解析的都是XML对象
0 请登录后投票
   发表时间:2010-02-23  
这贴有点水。
0 请登录后投票
   发表时间:2010-02-23   最后修改:2010-02-23
LZ的内容纯粹就是初学者的玩意。
0 请登录后投票
   发表时间:2010-02-24  
无聊可以读书写字,不要浪费能源
0 请登录后投票
   发表时间:2010-02-24  
LZ的内容贴出来,未免有点………………。耽误大家的时间,开始以为是什么有创意的东西,原来是这种内容。希望管理员好好审查一下。
0 请登录后投票
   发表时间:2010-02-24  
很水的帖。。。
0 请登录后投票
   发表时间:2010-02-24  
N 年前的东西
0 请登录后投票
   发表时间:2010-02-24  
我怎么把帖子删除了?

我解释一下:
我发这个帖子是有我的目的,不是给别人看的,是给我自己看了。
公司在搞信息安全,不让上网,我也好久没搞这方面的东西了,回家时间紧急在网上找了个这方面的东西,就放到这里了。
因为在公司可以访问这个网站,其它的网站不让访问。
0 请登录后投票
   发表时间:2010-02-24  
tyyz1314168 写道
我怎么把帖子删除了?

我解释一下:
我发这个帖子是有我的目的,不是给别人看的,是给我自己看了。
公司在搞信息安全,不让上网,我也好久没搞这方面的东西了,回家时间紧急在网上找了个这方面的东西,就放到这里了。
因为在公司可以访问这个网站,其它的网站不让访问。


删除是不可能的了。。。还是去看下版规吧
0 请登录后投票
论坛首页 入门技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics