DOM操作XML

本文演示了如何使用Java代码进行XML文件的读取、新建元素、元素修改、删除等基本操作,包括新建一本书、修改书籍信息、删除书籍及处理特定条件下的元素操作。

XML文件信息: 


JAVA代码:

package action;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;

import org.w3c.dom.*;
import org.xml.sax.SAXException;

import javax.xml.parsers.*;
import javax.xml.transform.*;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.*;
import javax.xml.xpath.*;

public class Test {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
		Element theBook = null, theElem = null, root = null;
		try {
			factory.setIgnoringElementContentWhitespace(true);

			DocumentBuilder db = factory.newDocumentBuilder();
			Document xmldoc = db.parse(new File("D:" + File.separator + "mldnwebdemo"
					+ File.separator + "test1.xml"));
			root = xmldoc.getDocumentElement();

			// --- 新建一本书开始 ----
			theBook = xmldoc.createElement("book");
			theElem = xmldoc.createElement("name");
			theElem.setTextContent("新书");
			theBook.appendChild(theElem);

			theElem = xmldoc.createElement("price");
			theElem.setTextContent("20");
			theBook.appendChild(theElem);

			theElem = xmldoc.createElement("memo");
			theElem.setTextContent("新书的更好看。");
			theBook.appendChild(theElem);
			root.appendChild(theBook);
			System.out.println("--- 新建一本书开始 ----");
			output(xmldoc);
			// --- 新建一本书完成 ----

			// --- 下面对《哈里波特》做一些修改。 ----
			// --- 查询找《哈里波特》----
			theBook = (Element) selectSingleNode("/books/book[name='哈里波特']",
					root);
			System.out.println("--- 查询找《哈里波特》 ----");
			output(theBook);
			// --- 此时修改这本书的价格 -----
			theBook.getElementsByTagName("price").item(0).setTextContent("15");// getElementsByTagName返回的是NodeList,所以要跟上item(0)。另外,getElementsByTagName("price")相当于xpath的".//price"。
			System.out.println("--- 此时修改这本书的价格 ----");
			output(theBook);
			// --- 另外还想加一个属性id,值为B01 ----
			theBook.setAttribute("id", "B01");
			System.out.println("--- 另外还想加一个属性id,值为B01 ----");
			output(theBook);
			// --- 对《哈里波特》修改完成。 ----

			// --- 要用id属性删除《三国演义》这本书 ----
			theBook = (Element) selectSingleNode("/books/book[@id='B02']", root);
			System.out.println("--- 要用id属性删除《三国演义》这本书 ----");
			output(theBook);
			theBook.getParentNode().removeChild(theBook);
			System.out.println("--- 删除后的XML ----");
			output(xmldoc);

			// --- 再将所有价格低于10的书删除 ----
			NodeList someBooks = selectNodes("/books/book[price<10]", root);
			System.out.println("--- 再将所有价格低于10的书删除 ---");
			System.out.println("--- 符合条件的书有 " + someBooks.getLength()
					+ "本。 ---");
			for (int i = 0; i < someBooks.getLength(); i++) {
				someBooks.item(i).getParentNode()
						.removeChild(someBooks.item(i));
			}
			output(xmldoc);

			saveXml("D:" + File.separator + "mldnwebdemo"
					+ File.separator + "Test1_Edited.xml", xmldoc);
		} catch (ParserConfigurationException e) {
			e.printStackTrace();
		} catch (SAXException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}

	public static void output(Node node) {// 将node的XML字符串输出到控制台
		TransformerFactory transFactory = TransformerFactory.newInstance();
		try {
			Transformer transformer = transFactory.newTransformer();
			transformer.setOutputProperty("encoding", "gb2312");
			transformer.setOutputProperty("indent", "yes");

			DOMSource source = new DOMSource();
			source.setNode(node);
			StreamResult result = new StreamResult();
			result.setOutputStream(System.out);

			transformer.transform(source, result);
		} catch (TransformerConfigurationException e) {
			e.printStackTrace();
		} catch (TransformerException e) {
			e.printStackTrace();
		}
	}

	public static Node selectSingleNode(String express, Object source) {// 查找节点,并返回第一个符合条件节点
		Node result = null;
		XPathFactory xpathFactory = XPathFactory.newInstance();
		XPath xpath = xpathFactory.newXPath();
		try {
			result = (Node) xpath
					.evaluate(express, source, XPathConstants.NODE);
		} catch (XPathExpressionException e) {
			e.printStackTrace();
		}

		return result;
	}

	public static NodeList selectNodes(String express, Object source) {// 查找节点,返回符合条件的节点集。
		NodeList result = null;
		XPathFactory xpathFactory = XPathFactory.newInstance();
		XPath xpath = xpathFactory.newXPath();
		try {
			result = (NodeList) xpath.evaluate(express, source,
					XPathConstants.NODESET);
		} catch (XPathExpressionException e) {
			e.printStackTrace();
		}

		return result;
	}

	public static void saveXml(String fileName, Document doc) {// 将Document输出到文件
		TransformerFactory transFactory = TransformerFactory.newInstance();
		try {
			Transformer transformer = transFactory.newTransformer();
			transformer.setOutputProperty("indent", "yes");

			DOMSource source = new DOMSource();
			source.setNode(doc);
			StreamResult result = new StreamResult();
			result.setOutputStream(new FileOutputStream(fileName));

			transformer.transform(source, result);
		} catch (TransformerConfigurationException e) {
			e.printStackTrace();
		} catch (TransformerException e) {
			e.printStackTrace();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		}
	}

}

控制台输出的运行结果:


内容概要:本文介绍了一个基于Matlab的综合能源系统优化调度仿真资源,重点实现了含光热电站、有机朗肯循环(ORC)和电含光热电站、有机有机朗肯循环、P2G的综合能源优化调度(Matlab代码实现)转气(P2G)技术的冷、热、电多能互补系统的优化调度模型。该模型充分考虑多种能源形式的协同转换与利用,通过Matlab代码构建系统架构、设定约束条件并求解优化目标,旨在提升综合能源系统的运行效率与经济性,同时兼顾灵活性供需不确定性下的储能优化配置问题。文中还提到了相关仿真技术支持,如YALMIP工具包的应用,适用于复杂能源系统的建模与求解。; 适合人群:具备一定Matlab编程基础和能源系统背景知识的科研人员、研究生及工程技术人员,尤其适合从事综合能源系统、可再生能源利用、电力系统优化等方向的研究者。; 使用场景及目标:①研究含光热、ORC和P2G的多能系统协调调度机制;②开展考虑不确定性的储能优化配置与经济调度仿真;③学习Matlab在能源系统优化中的建模与求解方法,复现高水平论文(如EI期刊)中的算法案例。; 阅读建议:建议读者结合文档提供的网盘资源,下载完整代码和案例文件,按照目录顺序逐步学习,重点关注模型构建逻辑、约束设置与求解器调用方式,并通过修改参数进行仿真实验,加深对综合能源系统优化调度的理解。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值