文档章节

Excel批量导出

zhaochaochao
 zhaochaochao
发布于 2015/10/12 10:42
字数 1040
阅读 5
收藏 0

Excel批量导出的一个Demo:

实体类:

package util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import domain.Person;

public class DBConnectionManager {
    public Connection getConnection(){
        Connection conn=null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            String url="jdbc:mysql://localhost:3306/ExcelDemo?user=root&password=123456";
            conn = DriverManager.getConnection(url);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return conn;
    }
    public List<Person> queryDataList(String sql){
        List<Person> list = new ArrayList<Person>();
        Connection conn = getConnection();
        for(int i=0;i<100000;i++){
            Person per = new Person();
            per.setId(i);
            per.setName("家第三方");
            per.setRemark("合适的开发哈拉少发的好啦");
            per.setCeshi("侧黑sIIS地方");
            per.setGrend(i+"等级");
            per.setSex(i+"男");
            list.add(per);
        }
        try {
           Statement stmt = conn.createStatement();
           ResultSet  rs = stmt.executeQuery(sql);
          while(rs.next()){
                Person per = new Person();
                per.setId(rs.getInt("id"));
               per.setName(rs.getString("name"));
                per.setRemark(rs.getString("remark"));
              list.add(per);
         }
    } catch (SQLException e) {
          e.printStackTrace();
      }
        return list;
    }
}
工具类:

package util;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;

import domain.Person;

public class DBConnectionManager {
    public Connection getConnection(){
        Connection conn=null;
        try {
            Class.forName("com.mysql.jdbc.Driver");
            String url="jdbc:mysql://localhost:3306/ExcelDemo?user=root&password=123456";
            conn = DriverManager.getConnection(url);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return conn;
    }
    public List<Person> queryDataList(String sql){
        List<Person> list = new ArrayList<Person>();
        Connection conn = getConnection();
        for(int i=0;i<100000;i++){
            Person per = new Person();
            per.setId(i);
            per.setName("家第三方");
            per.setRemark("合适的开发哈拉少发的好啦");
            per.setCeshi("侧黑sIIS地方");
            per.setGrend(i+"等级");
            per.setSex(i+"男");
            list.add(per);
        }
        try {
            Statement stmt = conn.createStatement();
            ResultSet  rs = stmt.executeQuery(sql);
            while(rs.next()){
                Person per = new Person();
                per.setId(rs.getInt("id"));
                per.setName(rs.getString("name"));
                per.setRemark(rs.getString("remark"));
                list.add(per);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return list;
    }
}
压缩

package util;

import java.io.FileInputStream;  

import java.io.FileOutputStream;  

import java.io.IOException;  

import java.util.zip.ZipEntry;  

import java.util.zip.ZipOutputStream;  


public class FileZip {

     /**  

     *   

     * @param srcfile 文件名数组  

     * @param zipfile 压缩后文件  

     */  

    public static void ZipFiles(java.io.File[] srcfile, java.io.File zipfile) {  

        byte[] buf = new byte[1024];  

        try {  

            ZipOutputStream out = new ZipOutputStream(new FileOutputStream(  

                    zipfile));  

            for (int i = 0; i < srcfile.length; i++) {  

                FileInputStream in = new FileInputStream(srcfile[i]);  

                out.putNextEntry(new ZipEntry(srcfile[i].getName()));  

                int len;  

                while ((len = in.read(buf)) > 0) {  

                    out.write(buf, 0, len);  

                }  

                out.closeEntry();  

                in.close();  

            }  

            out.close();  

        } catch (IOException e) {  

            e.printStackTrace();  

        }  

    }  


}
导出

package servlets;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;

import util.DBConnectionManager;
import domain.Person;

public class exportExcel extends HttpServlet {
    private String fileName;
    public void destroy() {
        super.destroy(); // Just puts "destroy" string in log
        // Put your code here
    }
    public void doGet(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        // 文件名获取
        Date date = new Date();
        SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss");
        String f = "Person-" + format.format(date);
        this.fileName = f;
        setResponseHeader(response);
        OutputStream out = null;
        try {
            System.out.println("导出excel开始~~~" + System.currentTimeMillis());
            long startTime = System.currentTimeMillis();
            out = response.getOutputStream();
            DBConnectionManager db = new DBConnectionManager();// 该部分是用于链接数据库
            List<Person> list = db.queryDataList("select * from person");// 查询数据集合
            toExcel(list, request, 65000, f, out);
            System.out.println("导出excel结束~~~" + System.currentTimeMillis());
            long endTime = System.currentTimeMillis();
            System.out.println("导出excel共花费时间~~~" + (endTime - startTime) / 1000);
        } catch (IOException e1) {
            e1.printStackTrace();
        } finally {
            try {
                out.flush();
                out.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }

    /** 设置响应头 */

    public void setResponseHeader(HttpServletResponse response) {
        try {
            response.setContentType("application/octet-stream;charset=UTF-8");
            response.setHeader("Content-Disposition", "attachment;filename="
            + java.net.URLEncoder.encode(this.fileName, "UTF-8")
            + ".zip");
            response.addHeader("Pargam", "no-cache");
            response.addHeader("Cache-Control", "no-cache");
        } catch (Exception ex) {
            ex.printStackTrace();
        }
    }
    public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
        doGet(request, response);
    }

    public void init() throws ServletException {
        // Put your code here
    }

    @SuppressWarnings("deprecation")
    public void toExcel(List<Person> list, HttpServletRequest request,

    int length, String f, OutputStream out) throws IOException {
        List<String> fileNames = new ArrayList();// 用于存放生成的文件名称s
        // File zip = new File(request.getRealPath("/excel") + f + ".zip");//
        // 压缩文件
        File zip = new File(request.getSession().getServletContext()
                .getRealPath("/excel")
                + f + ".zip");// 压缩文件
        // 生成excel
        for (int j = 0, n = list.size() / length + 1; j < n; j++) {
            Workbook book = new HSSFWorkbook();
            Sheet sheet = book.createSheet("person");
            double d = 0;// 用来统计
            String file = request.getSession().getServletContext()
                    .getRealPath("/excel")
                    + "/" + f + "-" + j+ ".xls";
            fileNames.add(file);
            FileOutputStream o = null;
            try {
                o = new FileOutputStream(file);

                Row row = sheet.createRow(0);
                row.createCell(0).setCellValue("ID");
                row.createCell(1).setCellValue("NAME");
                row.createCell(2).setCellValue("REMARK");
                
                row.createCell(3).setCellValue("sex");
                row.createCell(4).setCellValue("grend");
                row.createCell(5).setCellValue("ceshi");
                
                int m = 1;
                for (int i = 1, min = (list.size() - j * length + 1) > (length + 1) ? (length + 1)
                        : (list.size() - j * length + 1); i < min; i++) {
                    m++;
                    Person user = list.get(length * (j) + i - 1);
                    row = sheet.createRow(i);
                    row.createCell(0).setCellValue(user.getId());
                    row.createCell(1).setCellValue(user.getName());
                    row.createCell(2).setCellValue(user.getRemark());
                    
                    row.createCell(3).setCellValue(user.getSex());
                    row.createCell(4).setCellValue(user.getGrend());
                    row.createCell(5).setCellValue(user.getCeshi());
                    
                    
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
            try {
                book.write(o);
            } catch (Exception ex) {
                ex.printStackTrace();
            } finally {
                if (o != null) {
                    o.flush();
                    o.close();
                }
            }
        }
        File srcfile[] = new File[fileNames.size()];
        for (int i = 0, n = fileNames.size(); i < n; i++) {
            srcfile[i] = new File(fileNames.get(i));
        }
        util.FileZip.ZipFiles(srcfile, zip);
        FileInputStream inStream = new FileInputStream(zip);
        byte[] buf = new byte[4096];
        int readLength;
        while (((readLength = inStream.read(buf)) != -1)) {
            out.write(buf, 0, readLength);
        }
        inStream.close();
    }
}

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
    http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
  <servlet>
    <servlet-name>SimpleUpload</servlet-name>
    <servlet-class>servlets.SimpleUpload</servlet-class>
<!--    <load-on-startup>0</load-on-startup>-->
  </servlet>
  <servlet>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <servlet-name>Login</servlet-name>
    <servlet-class>servlets.Login</servlet-class>
  </servlet>
  <servlet>
    <description>This is the description of my J2EE component</description>
    <display-name>This is the display name of my J2EE component</display-name>
    <servlet-name>exportExcel</servlet-name>
    <servlet-class>servlets.exportExcel</servlet-class>
  </servlet>



  <servlet-mapping>
    <servlet-name>SimpleUpload</servlet-name>
    <url-pattern>/servlet/SimpleUpload</url-pattern>
  </servlet-mapping>
  <servlet-mapping>
    <servlet-name>Login</servlet-name>
    <url-pattern>/servlet/Login</url-pattern>
  </servlet-mapping>
  <servlet-mapping>
    <servlet-name>exportExcel</servlet-name>
    <url-pattern>/servlet/exportExcel</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>exportExcel.jsp</welcome-file>
  </welcome-file-list>
</web-app>

© 著作权归作者所有

共有 人打赏支持
zhaochaochao
粉丝 1
博文 85
码字总数 31195
作品 0
郑州
程序员
java使用什么技术实现excel数据的批量导入导出?

java使用什么技术实现excel数据的批量导入导出?大家有做过批量导入导出excel数据的项目吗?一般使用什么技术,数据量级别在10000条数据的,通过什么技术可以实现呢?

潘深练GS
2013/11/07
3.3K
5
报表开发之批量导入导出excel

在日常使用报表过程中,会有这样一种情况,你将Excel表分发给各个员工,员工填完后,统一整理成多个Excel,你需要将这些数据,用报表的填报功能,提交录入到数据库中,这样一来可避免到服务器...

九月你好123
2016/08/05
36
0
PHP导入Excel和导出数据为Excel文件

有时需要将Excel表格的数据导入到mysql数据库中,我们使用PHP的一个开源项目PHP-ExcelReader可以轻松实现Excel的导入。另外将mysql数据导出为Excel与本站上篇文章中导出CSV一样,只是将逗号分...

rin9958
2016/06/03
56
0
Egret之美术字批处理尝试(基础)

一 : 应用情景 ① , 如果游戏需要进军海外的时候,需要将一些通用的美术字批量转换成外语版的.本篇是基于 ps 2015 cc批量处理文本的初始探索 , 有不少的局限性. 二 : 步骤 1` 新建一个文本图层...

Aonaufly
06/29
0
0
IOS通讯录的隐藏标签(电话)的特殊功能

这功能比较适合有强迫症,爱折腾的人哈!! 规范了通讯录标签,以后可以轻松的知道别人是用短号还是亲情网给你打电话。 如果是长号还可以显示归属地。 也许从IOS8(不太清楚)开始自带了号码...

火冷
2016/06/27
723
0

没有更多内容

加载失败,请刷新页面

加载更多

安全管理标准

安全生产严重等级分类: 故障频次: 风险等级矩阵:

乔老哥
9分钟前
1
0
数据结构“树”的相关微视频

今天在腾讯视频上闲逛,然後发现一个叫“岚人”的用户上传了几段小视频,基本上都在5分钟以内,讲解了关于树的一些结构和算法。零代码,非常适合初学者入门。不过,对于老鸟来说,这也是非常...

Iridium
21分钟前
0
0
10-利用思维导图梳理JavaSE-Java 集合

10-利用思维导图梳理JavaSE-Java 集合 主要内容 1.Collection接口 2.Set接口 2.1.Set接口概述 2.2.HashSet类 2.3.TreeSet类 2.4.SortedSet接口 3.List接口 3.1.List接口概述 3.2.ArrayList类...

飞鱼说编程
32分钟前
3
0
活动推荐|互联网3.0与区块链新时代论坛(北京)

1 时间地点 **时间:**9月22日 14:00 - 18:00 地点:(北京海淀)西大街70号 3w咖啡 二层 2 活动详情 Harmony创始人Stephen及团队将介绍他们的区块链分片扩容技术。Stephen曾任Apple地图服务...

HiBlock
50分钟前
1
0
如何优雅的删除Redis的大key

关于Redis大键(Key),我们从[空间复杂性]和访问它的[时间复杂度]两个方面来定义大键。前者主要表示Redis键的占用内存大小;后者表示Redis集合数据类型(set/hash/list/sorted set)键,所含有的...

IT--小哥
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部