怎么使用java导出大数据为xml文件
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么使用java导出大数据为xml文件相关的知识,希望对你有一定的参考价值。
dom4j可以试试,不知道你的数据量有多大,如果太大的话,我没试过
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试试看
我这里有个简单的例子
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文件的主要内容,如果未能解决你的问题,请参考以下文章