文档章节

Excel批量导出

zhaochaochao
 zhaochaochao
发布于 2015/10/12 10:42
字数 1040
阅读 5
收藏 0
点赞 0
评论 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
博文 75
码字总数 25675
作品 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
禅道专业版 1.3 发布。暨敏捷之旅中国拉开帷幕!

禅道项目管理软件专业版1.3版本发布!该版本进一步完善批量导入功能、看板、工作日志和日历视图,论坛增加上传附件功能,修复了工作日志的Excel导出问题。 一、修复记录 实现Bug的Excel导入功...

炒蚕豆吃蹦豆
2012/11/06
3.1K
27
Spread 表格组件发布 V1.1 版本,支持最新 SSJSON 及 Xamarin.iOS

Spread 表格组件正式发布V1.1版本,新版本中再添新功能。本次新版本中包含两个主要功能和多个增强:对 SpreadJS 最新 JSON 的支持,和对 Xamarin.iOS 应用程序的支持。 新版本的主要更新点有...

葡萄城控件技术团队
2017/12/20
160
1
Birt导出Excel出现问题

@birtbird 你好,想跟你请教个问题: 在birt报表中新建的一个rptdesign中有多个table,在画的时候就出现了右边无法对齐的情况,更要命的是,在导出Excel的时候,有许多行是占用了多个Excel的...

GodStudy
2013/03/28
1K
2
Kendo UI常用示例汇总(四)

<Kendo UI Professional试用版下载> Kendo UI Professional 提供开源和商业两个版本。开源版 Kendo UI Core,有40+个框架和组件;商业版整合了之前的Kendo UI Web、Kendo UI Mobile 和 Kend...

Miss_Hello_World
2016/04/05
12
0
我想实现python +django ,web页面批量导出该如何做

我想实现python +django ,web页面批量导出,及时每条数据前面有个复选框,可以选择一些数据导出成excel或csv的,谢谢了

heima110
2015/08/30
200
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

about git flow

  昨天元芳做了git分支管理规范的分享,为了拓展大家关于git分支的认知,这里我特意再分享这两个关于git flow的链接,大家可以看一下。 Git 工作流程 Git分支管理策略   git flow本质上是...

qwfys
今天
2
0
Linux系统日志文件

/var/log/messages linux系统总日志 /etc/logrotate.conf 日志切割配置文件 参考https://my.oschina.net/u/2000675/blog/908189 dmesg命令 dmesg’命令显示linux内核的环形缓冲区信息,我们可...

chencheng-linux
今天
1
0
MacOS下给树莓派安装Raspbian系统

下载镜像 前往 树莓派官网 下载镜像。 点击 最新版Raspbian 下载最新版镜像。 下载后请,通过 访达 双击解压,或通过 unzip 命令解压。 检查下载的文件 ls -lh -rw-r--r-- 1 dingdayu s...

dingdayu
今天
1
0
spring boot使用通用mapper(tk.mapper) ,id自增和回显等问题

最近项目使用到tk.mapper设置id自增,数据库是mysql。在使用通用mapper主键生成过程中有一些问题,在总结一下。 1、UUID生成方式-字符串主键 在主键上增加注解 @Id @GeneratedValue...

北岩
今天
2
0
告警系统邮件引擎、运行告警系统

告警系统邮件引擎 cd mail vim mail.py #!/usr/bin/env python#-*- coding: UTF-8 -*-import os,sysreload(sys)sys.setdefaultencoding('utf8')import getoptimport smtplibfr......

Zhouliang6
今天
1
0
Java工具类—随机数

Java中常用的生成随机数有Math.random()方法及java.util.Random类.但他们生成的随机数都是伪随机的. Math.radom()方法 在jdk1.8的Math类中可以看到,Math.random()方法实际上就是调用Random类...

PrivateO2
今天
3
0
关于java内存模型、并发编程的好文

Java并发编程:volatile关键字解析    volatile这个关键字可能很多朋友都听说过,或许也都用过。在Java 5之前,它是一个备受争议的关键字,因为在程序中使用它往往会导致出人意料的结果。在...

DannyCoder
昨天
1
0
dubbo @Reference retries 重试次数 一个坑

在代码一中设置 成retries=0,也就是调用超时不用重试,结果DEBUG的时候总是重试,不是0吗,0就不用重试啊。为什么还是调用了多次呢? 结果在网上看到 这篇文章才明白 https://www.cnblogs....

奋斗的小牛
昨天
2
0
数据结构与算法3

要抓紧喽~~~~~~~放羊的孩纸回来喽 LowArray类和LowArrayApp类 程序将一个普通的Java数组封装在LowArray类中。类中的数组隐藏了起来,它是私有的,所以只有类自己的方法才能访问他。 LowArray...

沉迷于编程的小菜菜
昨天
1
0
spring boot应用测试框架介绍

一、spring boot应用测试存在的问题 官方提供的测试框架spring-boot-test-starter,虽然提供了很多功能(junit、spring test、assertj、hamcrest、mockito、jsonassert、jsonpath),但是在数...

yangjianzhou
昨天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部