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.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 
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

参考技术A 要看原始数据是怎样的追问

那个下面的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();

本回答被提问者和网友采纳
参考技术C 这个要去找jar包然后 自己写方法来存这些数据了

以上是关于JAVA 生成xml格式,具体格式如下,请问JAVA方法怎么写的主要内容,如果未能解决你的问题,请参考以下文章

基于soot的java方法名生成报告

请问用啥软件生成.xml文件,用啥软件生成html文件?

CXF解析svc?wsdl文件成java格式

请问Eclipse怎么识别xml文件

如何用java生成一个XML文件,并且将该文件压缩成ZIP格式后再写到硬盘上?

在java中如何实现http/post/xml发送数据报文?麻烦高手赐教!