Java对XML的读写操作类

import java.io.*;
import java.util.*;
import org.jdom.*;
import org.jdom.output.*;
import org.jdom.input.*;
public class XmlDo
{
	//============================================
	//创建XML文档
	//============================================
	public void BuildXML() throws Exception
	{
		//定义变量
		Element root, student, number, name, age;
		//生成根元素:student-info 
		root = new Element("student-info"); 
		//将根元素植入文档doc中
		Document doc = new Document(root); 
		//循环子结点
		for(int i=0;i<10;i++)
		{
			//生成元素:student,该元素中将包含元素number,name,age
			student = new Element("student"); 
			number = new Element("test");
			name = new Element("test");
			age = new Element("test");
			//设置各结点的值
			number.setText("test");
			name.setText("test");
			age.setText("test");
			//向student结点添加子结点
			student.addContent(number);
			student.addContent(name);
			student.addContent(age);
			//把student结点添加到根结点上
			root.addContent(student);
		}
		//创建格式化对象
		Format format = Format.getCompactFormat();
		//设置xml文件的字符为gb2312
		format.setEncoding("gb2312"); 
		//设置xml文件的缩进为4个空格
		format.setIndent("    "); 
		//在元素后换行,每一层元素缩排四格
		XMLOutputter XMLOut = new XMLOutputter(format); 
		//输出xml文档
		XMLOut.output(doc, new FileOutputStream("studentinfo.xml"));
	}
	//============================================
	//解析XML文档
	//============================================
	public void ParseXML() throws Exception
	{
		//注册解析器
		SAXBuilder builder = new SAXBuilder();
		//要读取的xml文档
		File file = new File("studentinfo.xml");
		//读取XML文档
		Document doc = builder.build(file);
		//得到根结点
		Element root = doc.getRootElement();
		//把根结点的子结点取出以list型式存
		List list = root.getChildren();
		//列出xml文档内容
		//readXML(list,root.getName());
		readXML(list,root.getName(),0);
	}
	//============================================
	//递归列出所有结点的函数
	//============================================
	public void readXML(List list,String root,int step) throws Exception
	{
		//父结点前空格
		for(int j=0;j<step*4;j++) {="" system.out.print("="" ");="" }="" 父结点名称="" system.out.println("<"+root+"="" style="margin: 0px; padding: 0px;">");
		//当前结点的子结点个数循环
		for(int i=0;i0)
			{
				//调用函数本身
				//readXML(tlist,item.getName()+"["+i+"]");
				readXML(tlist,item.getName(),step+1);
			}
			//子结点没有子结点时,输出结点内容及名称
			else
			{
				//输出对齐空格
				for(int j=0;j<(step+1)*4;j++)
				{
					System.out.print(" ");
				}
				System.out.println("<"+item.getName()+">"+item.getText()+"");
			}
		}
		//输出父结点对齐空格
		for(int j=0;j<step*4;j++) {="" system.out.print("="" ");="" }="" 父结点名称结尾="" system.out.println("<="" "+root+"="" style="margin: 0px; padding: 0px;">");
	}
	//============================================
	//main方法
	//============================================
	public static void main(String[] args) throws Exception
	{
		//创建对象
		XmlDo xml = new XmlDo();
		//创建xml文档
		System.out.println("正在创建XML文档 ...");
		xml.BuildXML();
		System.out.println("XML文档创建成功...");
		//读取xml文档
		System.out.println("正在读取XML文档...");
		xml.ParseXML();
		System.out.println("XML文档读取完毕...");
	}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.hexiang.utils; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; /** * 本类是专门解析XML文件的,主要用于为系统取自己的配置文件时提供最方便的解析操作 * @author HX * */ public class XmlManager { /** * 得到某节点下某个属性的值 * @param element 要获取属性的节点 * @param attributeName 要取值的属性名称 * @return 要获取的属性的值 * @author HX_2010-01-12 */ public static String getAttribute( Element element, String attributeName ) { return element.getAttribute( attributeName ); } /** * 获取指定节点下的文本 * @param element 要获取文本的节点 * @return 指定节点下的文本 * @author HX_2010-01-12 */ public static String getText( Element element ) { return element.getFirstChild().getNodeValue(); } /** * 解析某个xml文件,并在内存中创建DOM树 * @param xmlFile 要解析的XML文件 * @return 解析某个配置文件后的Document * @throws Exception xml文件不存在 */ public static Document parse( String xmlFile ) throws Exception { // 绑定XML文件,建造DOM树 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); DocumentBuilder db = dbf.newDocumentBuilder(); Document domTree = db.parse( xmlFile ); return domTree; } /** * 获得某节点下的某个子节点(指定子节点名称,和某个属性的值) * 即获取parentElement下名字叫childName,并且属性attributeName的值为attributeValue的子结点 * @param parentElement 要获取子节点的那个父节点 * @param childName 要获取的子节点名称 * @param attributeName 要指定的属性名称 * @param attributeValue 要指定的属性的值 * @return 符合条件的子节点 * @throws Exception 子结点不存在或有多个符合条件的子节点 * @author HX_2008-12-01 */ public static Element getChildElement( Element parentElement, String childName, String attributeName, String attributeValue ) throws Exception { NodeList list = parentElement.getElementsByTagName( childName ); int count = 0; Element curElement = null; for ( int i = 0 ; i < list.getLength() ; i ++ ) { Element child = ( Element )list.item( i ); String value = child.getAttribute( attributeName ); if ( true == value.equals( attributeValue ) ) { curElement =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值