JAVA 生成xml格式,具体格式如下,请问JAVA方法怎么写
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JAVA 生成xml格式,具体格式如下,请问JAVA方法怎么写相关的知识,希望对你有一定的参考价值。
<object name="message">
<object name="header">
<attribute name="authen_code" type="string" value="" required="true"/>
<attribute name="area_code" type="string" value="" required="true"/>
<attribute name="action_type" type="dic" value="" required="true"/>
<attribute name="action_time" type="calendar" value="" required="true"/>
<attribute name="target_id" type="calendar" value="" required="true"/>
<attribute name="target_type" type="dic" value="" required="true"/>
</object>
<object name="body">
<object name="project_info">
<attribute name="name" type="string" value="" required="true"/>
<attribute name="ss_code" type="string" value="" required="false"/>
<attribute name="area_code" type="string" value="" required="true"/>
<attribute name="tender_code" type="string" value="" required="false"/>
<attribute name="code" type="string" value="" required="false"/>
<attribute name="create_time" type="date" value="" required="true"/>
<attribute name="address" type="string" value="" required="false"/>
<list name="geom">
<object name="point1">
<attribute name="longitude" type="string" value="" required="true"/>
<attribute name="latitude" type="string" value="" required="true"/>
</object>
</list>
</object>
</object>
</object>
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
public static void main(String[] args)
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("Test1.xml"));
root=xmldoc.getDocumentElement();
theBook=(Element) selectSingleNode("/books/book[name='哈里波特']", root);
System.out.println("--- 查询找《哈里波特》 ----");
Element nameNode=(Element)theBook.getElementsByTagName("price").item(0);
String name=nameNode.getFirstChild().getNodeValue();
System.out.println(name);
output(theBook);
System.out.println("=============selectSingleNode(books/book[name='哈里波特'], root)==================");
//--- 新建一本书开始 ----
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);
System.out.println("==============================");
//--- 新建一本书完成 ----
//--- 下面对《哈里波特》做一些修改。 ----
//--- 查询找《哈里波特》----
//--- 此时修改这本书的价格 -----
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("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();
XML:
<?xml version="1.0" encoding="GBK"?>
<books>
<book>
<name>哈里波特</name>
<price>10</price>
<memo>这是一本很好看的书。</memo>
</book>
<book id="B02">
<name>三国演义</name>
<price>10</price>
<memo>四大名著之一。</memo>
</book>
<book id="B03">
<name>水浒</name>
<price>6</price>
<memo>四大名著之一。</memo>
</book>
<book id="B04">
<name>红楼</name>
<price>5</price>
<memo>四大名著之一。</memo>
</book>
</books>追问
这个我之前弄出来了,但是和人家要求的格式不对
追答具体哪里格式不一致?
追问我写的时候只能创建一个叫<object>的 节点,他给的都是<object>,然后下面那个对那个<attribute>里面属性赋值的时候,因为都是NAME ,所以它只能赋值给最后面一个name
那个下面的attribute 标签里面的元素我数据里面都没有,所以不知道怎么写JAVA 生成这种形式的XML了
java如何实现生成自定义Excel表格,如下图,
参考技术A 使用excel编好,再用jxl或poi填入数据 参考技术B 只写过简单的,你这个目测得花点心思,看下poi对列的操作说明吧追问我用过,但是没做过这么复杂的,请问您有相关java代码例子吗?
追答String path = "e:/test.xls";
OutputStream output = new FileOutputStream(path);
HSSFWorkbook hworkBook = null;
HSSFSheet writableSheet = null;
//Excel 可读可写工作簿
hworkBook = new HSSFWorkbook();
writableSheet = hworkBook.createSheet("test");
//添加Sheet的数据,可根据数据源封装
for(int i=0;i<10;i++)
System.out.println("i"+i);
HSSFRow row = writableSheet.createRow(i);
row.createCell(0).setCellValue("1866666666");
row.createCell(1).setCellValue("30");
hworkBook.write(output);
output.flush();
output.close();
以上是关于JAVA 生成xml格式,具体格式如下,请问JAVA方法怎么写的主要内容,如果未能解决你的问题,请参考以下文章