java动态导出excel压缩成zip下载的方法

 更新时间:2018年07月14日 12:39:32   作者:张虹旺  
这篇文章主要为大家详细介绍了java动态导出excel压缩成zip下载的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了java动态导出excel压缩成zip下载的具体代码,供大家参考,具体内容如下

package pack.java.io.demo;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.zip.ZipEntry;
import java.util.zip.ZipOutputStream;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.format.VerticalAlignment;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
 
/**
 * zip压缩文件实例
 * add by 周海涛
 * @author Administrator
 *
 */
public class ZipDemo {
 
 /**
 * @param args
 * @throws IOException 
 * @throws WriteException 
 * @throws RowsExceededException 
 */
 public static void main(String[] args) throws RowsExceededException, WriteException, IOException {
 String path = "C:/document/excel";
 //创建文件夹;
 createFile(path);
 //创建Excel文件;
 createExcelFile(path);
 //生成.zip文件;
 craeteZipPath(path);
 //删除目录下所有的文件;
 File file = new File(path);
 //删除文件;
 deleteExcelPath(file);
 //重新创建文件;
 file.mkdirs();
 }
 
 /**
 * 创建文件夹;
 * @param path
 * @return
 */
 public static String createFile(String path){
 File file = new File(path);
 //判断文件是否存在;
 if(!file.exists()){
  //创建文件;
  boolean bol = file.mkdirs();
  if(bol){
  System.out.println(path+" 路径创建成功!");
  }else{
  System.out.println(path+" 路径创建失败!");
  }
 }else{
  System.out.println(path+" 文件已经存在!");
 }
 return path;
 }
 
 /**
 * 在指定目录下创建Excel文件;
 * @param path
 * @throws IOException 
 * @throws WriteException 
 * @throws RowsExceededException 
 */
 public static void createExcelFile(String path) throws IOException, RowsExceededException, WriteException{
 for(int i =0;i<3;i++){
  //创建Excel;
  WritableWorkbook workbook = Workbook.createWorkbook(new File(path+"/" + new SimpleDateFormat("yyyyMMddHHmmsss").format(new Date() )+"_"+(i+1)+".xls"));
  //创建第一个sheet文件;
  WritableSheet sheet = workbook.createSheet("导出Excel文件", 0);
  //设置默认宽度;
  sheet.getSettings().setDefaultColumnWidth(30);
  
  //设置字体;
  WritableFont font1 = new WritableFont(WritableFont.ARIAL,14,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.RED);
 
  WritableCellFormat cellFormat1 = new WritableCellFormat(font1);
  //设置背景颜色;
  cellFormat1.setBackground(Colour.BLUE_GREY);
  //设置边框;
  cellFormat1.setBorder(Border.ALL, BorderLineStyle.DASH_DOT);
  //设置自动换行;
  cellFormat1.setWrap(true);
  //设置文字居中对齐方式;
  cellFormat1.setAlignment(Alignment.CENTRE);
  //设置垂直居中;
  cellFormat1.setVerticalAlignment(VerticalAlignment.CENTRE);
  //创建单元格
  Label label1 = new Label(0, 0, "第一行第一个单元格(测试是否自动换行!)",cellFormat1);
  Label label2 = new Label(1, 0, "第一行第二个单元格",cellFormat1);
  Label label3 = new Label(2, 0, "第一行第三个单元格",cellFormat1);
  Label label4 = new Label(3, 0, "第一行第四个单元格",cellFormat1);
  //添加到行中;
  sheet.addCell(label1);
  sheet.addCell(label2);
  sheet.addCell(label3);
  sheet.addCell(label4);
  
  //给第二行设置背景、字体颜色、对齐方式等等;
  WritableFont font2 = new WritableFont(WritableFont.ARIAL,14,WritableFont.NO_BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.BLUE2);
  WritableCellFormat cellFormat2 = new WritableCellFormat(font2);
  cellFormat2.setAlignment(Alignment.CENTRE);
  cellFormat2.setBackground(Colour.PINK);
  cellFormat2.setBorder(Border.ALL, BorderLineStyle.THIN);
  cellFormat2.setWrap(true);
 
  //创建单元格;
  Label label11= new Label(0, 1, "第二行第一个单元格(测试是否自动换行!)",cellFormat2);
  Label label22 = new Label(1, 1, "第二行第二个单元格",cellFormat2);
  Label label33 = new Label(2, 1, "第二行第三个单元格",cellFormat2);
  Label label44 = new Label(3, 1, "第二行第四个单元格",cellFormat2);
 
  sheet.addCell(label11);
  sheet.addCell(label22);
  sheet.addCell(label33);
  sheet.addCell(label44);
 
  //写入Excel表格中;
  workbook.write();
  //关闭流;
  workbook.close();
 }
 }
 
 /**
 * 生成.zip文件;
 * @param path
 * @throws IOException 
 */
 public static void craeteZipPath(String path) throws IOException{
 ZipOutputStream zipOutputStream = null;
 File file = new File(path+new SimpleDateFormat("yyyyMMddHHmmss").format(new Date())+".zip");
 zipOutputStream = new ZipOutputStream(new BufferedOutputStream(new FileOutputStream(file)));
 File[] files = new File(path).listFiles();
 FileInputStream fileInputStream = null;
 byte[] buf = new byte[1024];
 int len = 0;
 if(files!=null && files.length > 0){
  for(File excelFile:files){
  String fileName = excelFile.getName();
  fileInputStream = new FileInputStream(excelFile);
  //放入压缩zip包中;
  zipOutputStream.putNextEntry(new ZipEntry(path + "/"+fileName));
  
  //读取文件;
  while((len=fileInputStream.read(buf)) >0){
   zipOutputStream.write(buf, 0, len);
  }
  //关闭;
  zipOutputStream.closeEntry();
  if(fileInputStream != null){
   fileInputStream.close();
  }
  }
 }
 
 if(zipOutputStream !=null){
  zipOutputStream.close();
 }
 }
 
 /**
 * 删除目录下所有的文件;
 * @param path
 */
 public static boolean deleteExcelPath(File file){
 String[] files = null;
 if(file != null){
  files = file.list();
 }
 
 if(file.isDirectory()){
  for(int i =0;i<files.length;i++){
  boolean bol = deleteExcelPath(new File(file,files[i]));
  if(bol){
   System.out.println("删除成功!");
  }else{
   System.out.println("删除失败!");
  }
  }
 }
 return file.delete();
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Java实现一个简单的线程池代码示例

    Java实现一个简单的线程池代码示例

    线程池是管理线程的一个池子,通过阻塞队列管理任务,主要参数包括corePoolSize、maximumPoolSize、keepAliveTime等,这篇文章主要介绍了Java实现一个简单的线程池的相关资料,需要的朋友可以参考下
    2024-09-09
  • Nacos设置为windows自启动服务的步骤详解

    Nacos设置为windows自启动服务的步骤详解

    这篇文章给大家介绍了Nacos设置为windows自启动服务的操作步骤,文中通过代码示例和图文结合讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2023-12-12
  • SpringCloud学习笔记之OpenFeign进行服务调用

    SpringCloud学习笔记之OpenFeign进行服务调用

    OpenFeign对feign进行进一步的封装,添加了springmvc的一些功能,更加强大,下面这篇文章主要给大家介绍了关于SpringCloud学习笔记之OpenFeign进行服务调用的相关资料,需要的朋友可以参考下
    2022-01-01
  • idea与eclipse项目相互导入的过程(图文教程)

    idea与eclipse项目相互导入的过程(图文教程)

    这篇文章主要介绍了idea与eclipse项目相互导入的过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • 详细了解MVC+proxy

    详细了解MVC+proxy

    Java有两种代理方式,一种是静态代理,另一种是动态代理。对于静态代理,其实就是通过依赖注入,对对象进行封装,不让外部知道实现的细节。很多 API 就是通过这种形式来封装的
    2021-07-07
  • MybatisPlus如何处理Mysql的json类型

    MybatisPlus如何处理Mysql的json类型

    这篇文章主要介绍了MybatisPlus如何处理Mysql的json类型,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • 简单了解springboot中的配置文件相关知识

    简单了解springboot中的配置文件相关知识

    这篇文章主要介绍了简单了解springboot中的配置文件相关知识,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • 浅谈java安全编码指南之死锁dead lock

    浅谈java安全编码指南之死锁dead lock

    java中为了保证共享数据的安全性,我们引入了锁的机制。有了锁就有可能产生死锁。死锁的原因就是多个线程锁住了对方所需要的资源,然后现有的资源又没有释放,从而导致循环等待的情况。通常来说如果不同的线程对加锁和释放锁的顺序不一致的话,就很有可能产生死锁。
    2021-06-06
  • Java Collection 接口和常用方法综合详解

    Java Collection 接口和常用方法综合详解

    Collection派生出三个子接口,Set代表不可重复的无序集合、List代表可重复的有序集合、Queue是java提供的队列实现,通过它们不断的扩展出很多的集合类,接下来我们详细介绍一下
    2021-11-11
  • 教你用java完美封装微信模板消息的发送动态

    教你用java完美封装微信模板消息的发送动态

    这篇文章主要介绍了教你用java完美封装微信模板消息的发送动态,文中有非常详细的代码示例,对正在学习java的小伙伴们有很好的帮助,需要的朋友可以参考下
    2021-04-04

最新评论