JAVA用DOM方式读取xml文件

Status.xml

<?xml version="1.0" encoding="UTF-8"?>
<StatuList>
    <Statu id="1">
        <id>1</id>
        <name>待机</name>
        <status>00H</status>
    </Statu>
    <Statu id="2">
        <id>2</id>
        <name>停机</name>
        <status>01H</status>
    </Statu>
    <Statu id="3">
        <id>3</id>
        <name>启动</name>
        <status>02H</status>
    </Statu>

</StatuList>

解析xml代码如下:

import java.io.InputStream;
import java.util.ArrayList;  
import java.util.HashMap;
import java.util.List;  
import java.util.Map;
import javax.xml.parsers.DocumentBuilder;  
import javax.xml.parsers.DocumentBuilderFactory;  
import javax.xml.parsers.ParserConfigurationException;  
import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
import org.w3c.dom.Document;  
import org.w3c.dom.NamedNodeMap;  
import org.w3c.dom.NodeList;  
 
 
    /**
     * 用DOM方式读取xml文件
     * @author lune
     */  
    public class ReadxmlByDom {  
        private static DocumentBuilderFactory dbFactory = null;  
        private static DocumentBuilder db = null;  
        private static Document document = null;  
        private static List<Map<String, Object>> status = null;  
        static{  
            try {  
                dbFactory = DocumentBuilderFactory.newInstance();  
                db = dbFactory.newDocumentBuilder();  
            } catch (ParserConfigurationException e) {  
                e.printStackTrace();  
            }  
        }  
    
    public Document getDocument(String url) throws DocumentException{
            SAXReader reader = new SAXReader();
            InputStream in = getClass().getClassLoader().getResourceAsStream(url);//读取文件流,Url为controller.xml文件
            //File file=new File(url);
            Document document = (Document) reader.read(in);//获得文件实例
            return document;
     }
    
    public static List<Map<String,Object>> getStatus(String fileName) throws Exception{  
        //将给定 URI 的内容解析为一个 XML 文档,并返回Document对象  
        document = db.parse(fileName);  
        //按文档顺序返回包含在文档中且具有给定标记名称的所有 Element 的 NodeList  
        NodeList bookList = document.getElementsByTagName("Statu");  
        status = new ArrayList<Map<String,Object>>();  
        //遍历status  
        for(int i=0;i<bookList.getLength();i++){  
            Map<String,Object> statu = new HashMap<String,Object>();  
            //获取第i个statu结点  
            org.w3c.dom.Node node = bookList.item(i);  
            //获取第i个statu的所有属性  
            NamedNodeMap namedNodeMap = node.getAttributes();  
            //获取已知名为id的属性值  
            String id = namedNodeMap.getNamedItem("id").getTextContent();//System.out.println(id);  
            statu.put("id", Integer.parseInt(id));
              
            //获取statu结点的子节点,包含了Test类型的换行  
            NodeList cList = node.getChildNodes();//System.out.println(cList.getLength());9  
              
            //将一个statu里面的属性加入数组  
            ArrayList<String> contents = new ArrayList<>();  
            for(int j=1;j<cList.getLength();j+=2){  
                org.w3c.dom.Node cNode = cList.item(j);  
                String content = cNode.getFirstChild().getTextContent();  
                contents.add(content);  
            }  
            statu.put("name", contents.get(1));  
            statu.put("status", contents.get(2));  
            status.add(statu);  
        }  
        return status;  
    }  
          
    public static void main(String[] args) {
        try {
            System.out.println(getStatus("src/com/beidou/xml/parser/Status.xml"));
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

输出结果:[{id=1, status=00H, name=待机}, {id=2, status=01H, name=停机}, {id=3, status=02H, name=启动}]

备注:部署到linux服务器上时,文件地址可写这样:

String path = getClass().getClassLoader().getResource("/com/beidou/xml/parser/Status.xml").getPath();


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这个问题我可以回答。以下是Java使用dom4j读取XML文件的基本步骤: 1. 导入dom4j的jar包 你可以通过maven或手动下载jar包的方式导入dom4j的jar包。 2. 创建SAXReader对象 SAXReaderdom4j的核心类,用于读取XML文件并将其转换为Document对象。 3. 加载XML文件 使用SAXReader对象的read方法加载XML文件,并将其转换为Document对象。 4. 获取根节点 通过Document对象的getRootElement方法获取XML文件的根节点。 5. 遍历节点 可以使用递归的方式遍历XML文件的节点,获取节点的名称、属性、子节点等信息。 下面是一个简单的示例代码: ```java import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import java.io.File; public class Dom4jDemo { public static void main(String[] args) { try { // 创建SAXReader对象 SAXReader reader = new SAXReader(); // 加载XML文件 Document document = reader.read(new File("example.xml")); // 获取根节点 Element root = document.getRootElement(); // 遍历节点 print(root); } catch (Exception e) { e.printStackTrace(); } } public static void print(Element element) { // 输出节点名称 System.out.println(element.getName()); // 输出节点属性 List<Attribute> attributes = element.attributes(); for (Attribute attribute : attributes) { System.out.println(attribute.getName() + ": " + attribute.getValue()); } // 输出子节点 List<Element> elements = element.elements(); for (Element e : elements) { print(e); } } } ``` 以上是一个简单的dom4j读取XML文件的示例代码,希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值