文档章节

Excel批量导出

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

精选30+云产品,助力企业轻松上云!>>>

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
博文 113
码字总数 41204
作品 0
郑州
程序员
私信 提问
加载中
请先登录后再评论。
报表如何批量导出成 excel 文件

需求说明 报表展现后可以通过工具栏中的导出按钮将当前展现的报表导出成 excel 文件,但是在实际使用中通常会要求报表不需要展现,直接通过一些操作将报表导出成 excel 文件,并且往往会要求...

泡泡糖儿
2019/11/06
6
0
报表如何批量导出成 excel 文件

需求说明 报表展现后可以通过工具栏中的导出按钮将当前展现的报表导出成 excel 文件,但是在实际使用中通常会要求报表不需要展现,直接通过一些操作将报表导出成 excel 文件,并且往往会要求...

泡泡糖儿
2019/12/02
16
0
如何将数据库中的数据导成 excel 文件

这个要看下具体格式,如果只是将数据库中的明细数据逐条导出到 excel 中的话,这个直接使用开源的 poi 就行,具体可以直接百度下,但是这种实际上没多大意义,大多数的需求是要求按照特定的格...

泡泡糖儿
06/28
8
0
Java使用 POI 操作Excel

  Java中常见的用来操作 Excel 的方式有2种:JXL和POI。JXL只能对 Excel进行操作,且只支持到 Excel 95-2000的版本。而POI是Apache 的开源项目,由Java编写的跨平台 Java API,可操作 Micr...

osc_uewtwxky
2019/06/01
21
0
excel 导入导出测试点

目前,为方便操作,很多系统都会增加批量导入导出的功能。文件导入导出一般格式都是excel。由于用户直接在excel在填写内容,无法控制填写的格 式,加上excel解析比较困难,所以一般涉及到exc...

osc_b07navmi
2019/12/11
2
0

没有更多内容

加载失败,请刷新页面

加载更多

跨越了6个阶段,我仍然是生物信息学初学者

首先非常欢迎大家分享自己与生物信息学/生信技能树的故事! 上一期是:我如何从生物科学到生物信息 这一期是我在朋友圈看到了我们单细胞天地常驻编辑周运来的真情流露,邀请他投稿的我们生信...

biotrainee
前天
0
0
网飞是如何运用心理学来完善其客户体验的

原文地址:https://36kr.com/p/5289228 译者:俊一 占据全球网站流量 15%的奈飞,其用户体验设计背后有哪些秘密? 神译局是 36 氪旗下编译团队,关注科技、商业、职场、生活等领域,重点介绍...

高行
02/08
0
0
shell编程中的循环脚本

本文中的部分脚本来源于网络,就不申明原创了,如果这些东西自己学会了,那就是属于自己的了。 求从1加到100的和 使用for循环求和: #!/bin/bash declare -i sum=0 for ((i=1;i<=100;i++));...

Double_冬
2018/08/16
0
0
智能合约:介绍、geth、Ethereum Wallet

从看雪论坛换了一本《智能合约安全分析和审计指南》,看了一些智能合约相关的内容,因为我之前对于区块链的了解仅仅是只知道世界上有一种叫做比特币的东西,所以对于这些概念的理解还是比较困...

yichen115
04/26
0
0
Vue和React技术风格上的不同

在主流框架中,Vue和React都属于全球热门,各自有着大量用户,两者之间的优缺点便带来了众多讨论。 那么这两者之间的关键区别在于哪些方面?为何熟练掌握Vue成为越来越多公司的岗位要求? Vu...

若川
07/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部