jdom解析XML示例代码

21 篇文章 0 订阅
package com.twthinker.config;


import java.io.*;
import java.util.*;
import org.jdom.*;
import org.jdom.input.*;

/**
*

Title: 读取xml文件信息


*

Des.c.r.i.p.tion: 从XML配置文件中获得配置信息。excerpt form jdom。


*

Copyright: Copyright (c) 2005


*

Company: www.fulitong.com.cn


* @author nazx
* @version 1.0
*/

public class XmlReader {
//private ErrorLogs errlogs = new ErrorLogs();
protected Element m_RootElement = null;

/**
* 构造函数。
* @param xmlFile 要读取的配置文件的绝对路径。
*/
public XmlReader(String xmlFile) {
try {
SAXBuilder builder = new SAXBuilder();
Document doc = null;
doc = builder.build(new FileInputStream(xmlFile));
m_RootElement = doc.getRootElement();
}
catch (IOException ex) {
System.out.println("XmlReader构造时出现IO错误:" + ex.toString());
}
catch (JDOMException ex1) {
System.out.println("XmlReader构造时分析XML文件出错:" + ex1.toString());
}
catch (Exception ex) {
System.out.println("XmlReader 构造出错:" + ex.toString());
}
}
//Element root = doc.getRootElement(); //得到根元素
//List books = root.getChildren(); //得到根元素所有子元素的集合
/**
* 从配置文件中获得全部配置信息。
* @return 配置信息组成的List对象。
*/
public List getElementList()
{
Element root = getElement(null, null) ;
//System.out.println("m_RootElement="+root);
List xmlinfo = root.getChildren(); //得到根元素所有子元素的集合
//System.out.println("xmlinfo.size():"+xmlinfo.size());
return xmlinfo;
}
/**
* 从配置文件中获得配置信息。
* @param key 要获取的配置节点名称。
* @param curRootName 查找的起始节点名称,如果为null从根开始查找。
* @return 配置的字符串。
*/
public String getElementValue(String curRootName, String key) {
String value = null;
Element curRoot = getElement(null, curRootName);
if (null == curRoot) {
curRoot = m_RootElement;
}
Element keyNode = getElement(curRoot, key);
if (null != keyNode) {
value = keyNode.getTextTrim();
}
return value;
}

/**
* 根据名字获得节点。广度遍历,递归调用。
* @param nodeName 节点的名字。
* @param curRoot 从开始查找的起始节点,如果为null从根开始查找。
* @return 返回从指定节点下找到的第一个节点。如果没有返回null。
*/
public Element getElement(Element curRoot, String nodeName) {
Element retElement = null;

if (null == nodeName)
return m_RootElement;

if (null == curRoot) {
curRoot = m_RootElement;
}

if (null != curRoot) {
retElement = curRoot.getChild(nodeName);
if (null == retElement) {
List nestElements = curRoot.getChildren();
Iterator iterator = nestElements.iterator();
while (iterator.hasNext() && null == retElement) {
retElement = getElement( (Element) iterator.next(), nodeName);
}
}
}

return retElement;
}

/**
* 获得指定节点的属性。
* @param elementName 节点的名称。
* @param attName 要获得的属性的名称。
* @return 要查找的属性的值。
*/
public String getElementAtrribute(String elementName, String attName)
{
Element el = getElement(null, elementName);
if (null == el) return null;
return el.getAttributeValue(attName);
}

}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 好的,我可以回答你关于Java解析XML代码的问题。 在Java中,可以使用多种方法来解析XML文档。以下是一些常用的方法: 1. 使用Java内置的DOM解析器:DOM(文档对象模型)是一种基于树结构的解析器,它将整个XML文档解析为一棵树,可以方便地对节点进行操作。 2. 使用Java内置的SAX解析器:SAX(简单API for XML)是一种基于事件驱动的解析器,它逐行读取XML文档并触发事件,可以在读取XML文档时进行处理。 3. 使用第三方库,如JDOM、DOM4J等:这些库提供了更方便的API来解析XML文档。 下面是一个使用DOM解析解析XML文档的示例代码: ```java import javax.xml.parsers.*; import org.w3c.dom.*; public class DomParserExample { public static void main(String[] args) { try { // 创建解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建解析器 DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件 Document doc = builder.parse("file.xml"); // 获取根节点 Element root = doc.getDocumentElement(); // 遍历子节点 NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取节点名称和值 System.out.println(element.getTagName() + ": " + element.getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 这个示例代码使用DOM解析解析了名为"file.xml"的XML文档,并打印出每个子节点的名称和值。 ### 回答2: Java解析XML代码可以使用Java内置的API或者使用第三方库来进行操作。以下是使用Java内置的API解析XML代码示例: ```java // 导入相关的包 import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; public class XMLParser { public static void main(String[] args) { try { // 创建解析器工厂 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 创建解析器 DocumentBuilder builder = factory.newDocumentBuilder(); // 解析XML文件 Document document = builder.parse("example.xml"); // 获取根节点 Element root = document.getDocumentElement(); // 获取子节点列表 NodeList nodeList = root.getChildNodes(); // 遍历子节点 for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); // 判断节点类型为元素节点 if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取节点的标签名和内容 String tagName = element.getTagName(); String textContent = element.getTextContent(); // 输出节点信息 System.out.println("标签名:" + tagName); System.out.println("内容:" + textContent); System.out.println("----------------------------"); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上示例代码使用了Java提供的XML解析器,首先创建解析器工厂和解析器,然后通过解析解析XML文件。接下来获取根节点和子节点列表,然后遍历子节点。在遍历过程中,判断节点类型为元素节点,然后获取节点的标签名和内容,并输出节点信息。 使用以上代码可以快速实现对XML文件的解析。当然,也可以考虑使用第三方库,如DOM4J、JDOM或者SAX等。这些库提供了更多的灵活性和功能,可以根据需求选择合适的库来进行XML解析。 ### 回答3: Java解析XML是通过使用XML解析器来读取和解析XML文档的过程。 Java中有几种解析XML的方式,常用的有DOM和SAX两种。 DOM解析方式将整个XML文档加载到内存中的DOM树中,然后可以通过调用节点的方法来访问和操作XML元素和属性。使用DOM解析XML的步骤包括创建解析器、加载XML文档、获取根节点、遍历解析树,以及获取和操作节点的属性和元素等。DOM解析方式适用于需要对整个XML文档进行操作的场景,但是对大型XML文档的解析可能会占用较多的内存空间。 SAX解析方式是事件驱动的,通过触发不同事件来处理XML文档中的数据。使用SAX解析XML的步骤包括创建解析器、实现事件处理方法、注册事件监听器,并通过解析解析XML文档。SAX解析方式适用于对XML文档进行逐行处理的场景,它具有较低的内存消耗,但是相对DOM方式,编码复杂度较高。 不论使用哪种方式解析XML,都需要首先导入相关的解析器库,如使用DOM解析方式可以使用javax.xml.parsers包下的DocumentBuilder类,使用SAX解析方式可以使用org.xml.sax包下的SAXParser类。 写一个简单的XML解析程序示例: ```java import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; public class XMLParser { public static void main(String[] args) { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document doc = builder.parse("example.xml"); Element root = doc.getDocumentElement(); System.out.println("Root element: " + root.getNodeName()); NodeList nodeList = root.getChildNodes(); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; System.out.println("Element: " + element.getNodeName()); System.out.println("Value: " + element.getTextContent()); } } } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码使用了DOM方式解析XML文档,首先创建解析器工厂、解析器和DOM文档对象,并指定需要解析XML文件路径,然后通过获取根节点和遍历子节点,打印出XML文档的节点名称和内容。 这只是一个简单的例子,实际应用中可能需要根据需要进行更复杂的XML解析操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值