怎么使用java导出大数据为xml文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么使用java导出大数据为xml文件相关的知识,希望对你有一定的参考价值。

    dom4j可以试试,不知道你的数据量有多大,如果太大的话,我没试过
    xml文件是有规律的,你可以把要导出的数据构造一下,

    我有个简单的代码

package com.test.xml;

import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class Dom4JXML 
    
    public void createXML() 
        //用工厂类创建一个document实例
        Document doc = DocumentHelper.createDocument();
        //创建根元素emps
        Element rootEle = doc.addElement("emps");
        //添加注释
        rootEle.addComment("这是一个dom4j生成的xml文件");
        //emps根节点下创建一个emp节点
        Element empEle = rootEle.addElement("emp");
        //emp添加属性id="1"
        empEle.addAttribute("id", "1");
        //emp节点下创建一个name节点
        Element nameEle = empEle.addElement("name");
        //name节点下创建一个文本节点zhangsan
        nameEle.setText("zhangsan");
        //再为name节点创建一个兄弟节点
        Element sexEle = empEle.addElement("sex");
        sexEle.setText("man");
        //将document中的内容写入文件中
        try 
            Writer out = new FileWriter("F:\\\\emps.xml");
            //格式化输出,类型IE浏览一样
            OutputFormat format = OutputFormat.createPrettyPrint();
            //OutputFormat format = OutputFormat.createCompactFormat();
            format.setEncoding("UTF-8");
            //创建写出对象
            XMLWriter writer = new XMLWriter(out,format);
            writer.write(doc);
            writer.close();
            System.out.println("生成emps.xml成功。");
         catch (IOException e) 
            // TODO Auto-generated catch block
            e.printStackTrace();
            System.out.println("失败了。");
        
    
    
    public static void main(String[] args) 
        new Dom4JXML().createXML();
    

    然而从xml文件中解析以后的数据收集可以用SAX试试看
    我这里有个简单的例子

package com.test.xml;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
public class SAXParseHandler extends DefaultHandler
public void startDocument()throws SAXException
System.out.println("起始文挡");

public void endDocument()throws SAXException
System.out.println("结束文挡");

public void characters(char[] ch,int start,int length)throws SAXException
String charString=new String(ch,start,length);
System.out.println("字符:"+charString);

public void startElement(String namespaceURI,String localName,String qName,Attributes atts)throws SAXException
System.out.println("起始元素:"+qName);
for(int i=0;i<atts.getLength();i++)
System.out.println("属性值:"+atts.getValue(i));


public void endElement(String namespaceURI,String localName,String qName)throws SAXException
System.out.println("结束元素:"+qName);


package com.test.xml;

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

public class Books 
/**
 * @param args
 */
public static void main(String[] args) throws Exception
// TODO 自动生成方法存根
SAXParserFactory factory=SAXParserFactory.newInstance();
SAXParser parser=factory.newSAXParser();
parser.parse("booksamp.xml",new SAXParseHandler());


参考技术A dom4j可以试试,不知道你的数据量有多大,如果太大的话,我没试过
xml文件是有规律的,可以把要导出的数据构造一下,

我有个简单的代码,在这分享一下,希望对LZ有用
package com.test.xml;

import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.XMLWriter;
public class Dom4JXML

public void createXML()
//用工厂类创建一个document实例
Document doc = DocumentHelper.createDocument();
//创建根元素emps
Element rootEle = doc.addElement("emps");
//添加注释
rootEle.addComment("这是一个dom4j生成的xml文件");
//emps根节点下创建一个emp节点
Element empEle = rootEle.addElement("emp");
//emp添加属性id="1"
empEle.addAttribute("id", "1");
//emp节点下创建一个name节点
Element nameEle = empEle.addElement("name");
//name节点下创建一个文本节点zhangsan
nameEle.setText("zhangsan");
//再为name节点创建一个兄弟节点
Element sexEle = empEle.addElement("sex");
sexEle.setText("man");
//将document中的内容写入文件中
try
Writer out = new FileWriter("F:\\emps.xml");
//格式化输出,类型IE浏览一样
OutputFormat format = OutputFormat.createPrettyPrint();
//OutputFormat format = OutputFormat.createCompactFormat();
format.setEncoding("UTF-8");
//创建写出对象
XMLWriter writer = new XMLWriter(out,format);
writer.write(doc);
writer.close();
System.out.println("生成emps.xml成功。");
catch (IOException e)
// TODO Auto-generated catch block
e.printStackTrace();
System.out.println("失败了。");



public static void main(String[] args)
new Dom4JXML().createXML();

java用freemarker导出数据到word(含多图片)

一、制作word模版

新建word文档,按照需要设置好字体等各种格式;这里为了显得整齐使用了无边框的表格。

将word文档另存为xml文件(注意不是word xml文档,我吃了这家伙的大亏了)

 

然后用文本编辑器打开这个xml文件,将需要动态显示的文字替换为变量,如:${topicName},

图片需要1.将w:binData标签的一堆字符替换成将来包含图片字符的变量2.为了防止生成多图时出错,将v:shape标签的id属性、v:imagedata标签的src属性、w:binData标签的w:name属性替换为变量,这里变量可以像EL表达式一样写在字符串里面,使用形如${var_index}这样的表达式可以获取当前list遍历到的变量索引。

1 <w:pict><w:binData w:name="wordml://${module_index}_${childModule_index}.png">${childModule.src}</w:binData><v:shape id="_x0000_s1026_${module_index}_${childModule_index}" o:spt="75" alt="${childModule.name}" type="#_x0000_t75" style="height:240pt;width:300pt;" filled="f" o:preferrelative="t" stroked="f" coordsize="21600,21600"><v:path/><v:fill on="f" focussize="0,0"/><v:stroke on="f" joinstyle="miter"/><v:imagedata src="wordml://${module_index}_${childModule_index}.png" o:title="${childModule.name}"/><o:lock v:ext="edit" aspectratio="t"/><w10:wrap type="none"/><w10:anchorlock/></v:shape></w:pict>

添加<#list></#list>标签的时候注意标签的位置,看清包含了哪些标签。代码多的快看花眼了(tbl害人啊),使用一个有高亮显示的编辑器何其重要!

搞定后后缀名改为ftl,放到项目中。

二、bean配置,我用了官方文档的最简单配置

1 <!-- freemarkerTemplate -->
2     <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
3        <property name="templateLoaderPath">
4            <value>classpath:/templates/freemarker/</value>
5        </property>
6      </bean>

 

三、controller组织数据

1 @Resource(name="freemarkerConfig") private FreeMarkerConfigurer freemarkerConfig;

这里只贴过来了部分核心代码

1 List<ModuleParam> moduleList = JSONObject.parseArray(json.get("parentList").toString(), ModuleParam.class);
2         String topicName = json.get("topicName").toString();
3         String topicId = json.get("topicId").toString();
4         String summarize = json.get("summarize").toString();
5 
6         Map<String,Object> dataMap = new HashMap<String,Object>();
7         dataMap.put("moduleList", moduleList);
8         dataMap.put("topicName",topicName);
9         dataMap.put("summarizeContent",summarize);
 1 Configuration configuration = freemarkerConfig.getConfiguration();
 2         configuration.setDefaultEncoding("UTF-8");
 3         Template t=null;  
 4         t = configuration.getTemplate("reportTemplate.ftl");  
 5         File outFile = new File(fileName);  
 6         Writer out = null;  
 7         FileOutputStream fos=null;  
 8         try{
 9            fos = new FileOutputStream(outFile);  
10            out = new BufferedWriter(new OutputStreamWriter(fos,"UTF-8"));
11            t.process(dataMap, out);  
12        }finally{
13            if(out != null){
14                out.close();
15            }
16            if(fos != null){
17                fos.close();
18            }
19        }

基本就这些啦~~

参考:

Java用freemarker导出word http://blog.csdn.net/wangqiuyun/article/details/26348819

Java多种方式动态生成doc文档:http://www.cnblogs.com/Joanna-Yan/p/5280272.html

推荐 :freemarker系列

以上是关于怎么使用java导出大数据为xml文件的主要内容,如果未能解决你的问题,请参考以下文章

java怎么将数据导出为xml文件

POI实现大数据EXCLE导入导出,解决内存溢出问题

java 大数据量导出Excel内存溢出,求解答!

java poi Excel大数据量导入怎么提高速度

怎么使用java Poi解决导入excel表格大数据量时的内存溢出问

poi导出大数据,报内存溢出怎么解决