欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java動態(tài)導出excel壓縮成zip下載的方法

 更新時間:2018年07月14日 12:39:32   作者:張虹旺  
這篇文章主要為大家詳細介紹了java動態(tài)導出excel壓縮成zip下載的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java動態(tài)導出excel壓縮成zip下載的具體代碼,供大家參考,具體內(nèi)容如下

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";
 //創(chuàng)建文件夾;
 createFile(path);
 //創(chuàng)建Excel文件;
 createExcelFile(path);
 //生成.zip文件;
 craeteZipPath(path);
 //刪除目錄下所有的文件;
 File file = new File(path);
 //刪除文件;
 deleteExcelPath(file);
 //重新創(chuàng)建文件;
 file.mkdirs();
 }
 
 /**
 * 創(chuàng)建文件夾;
 * @param path
 * @return
 */
 public static String createFile(String path){
 File file = new File(path);
 //判斷文件是否存在;
 if(!file.exists()){
  //創(chuàng)建文件;
  boolean bol = file.mkdirs();
  if(bol){
  System.out.println(path+" 路徑創(chuàng)建成功!");
  }else{
  System.out.println(path+" 路徑創(chuàng)建失敗!");
  }
 }else{
  System.out.println(path+" 文件已經(jīng)存在!");
 }
 return path;
 }
 
 /**
 * 在指定目錄下創(chuàng)建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++){
  //創(chuàng)建Excel;
  WritableWorkbook workbook = Workbook.createWorkbook(new File(path+"/" + new SimpleDateFormat("yyyyMMddHHmmsss").format(new Date() )+"_"+(i+1)+".xls"));
  //創(chuàng)建第一個sheet文件;
  WritableSheet sheet = workbook.createSheet("導出Excel文件", 0);
  //設(shè)置默認寬度;
  sheet.getSettings().setDefaultColumnWidth(30);
  
  //設(shè)置字體;
  WritableFont font1 = new WritableFont(WritableFont.ARIAL,14,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.RED);
 
  WritableCellFormat cellFormat1 = new WritableCellFormat(font1);
  //設(shè)置背景顏色;
  cellFormat1.setBackground(Colour.BLUE_GREY);
  //設(shè)置邊框;
  cellFormat1.setBorder(Border.ALL, BorderLineStyle.DASH_DOT);
  //設(shè)置自動換行;
  cellFormat1.setWrap(true);
  //設(shè)置文字居中對齊方式;
  cellFormat1.setAlignment(Alignment.CENTRE);
  //設(shè)置垂直居中;
  cellFormat1.setVerticalAlignment(VerticalAlignment.CENTRE);
  //創(chuàng)建單元格
  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);
  
  //給第二行設(shè)置背景、字體顏色、對齊方式等等;
  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);
 
  //創(chuàng)建單元格;
  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();
  //關(guān)閉流;
  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);
  }
  //關(guān)閉;
  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();
 }
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java實現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的示例

    Java實現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的示例

    這篇文章主要介紹了Java實現(xiàn)Word/Pdf/TXT轉(zhuǎn)html的示例,幫助大家方便的進行文件格式轉(zhuǎn)換,完成需求,感興趣的朋友可以了解下
    2020-11-11
  • 通Java接口上傳實現(xiàn)SMMS圖床

    通Java接口上傳實現(xiàn)SMMS圖床

    這篇文章主要介紹了通Java接口上傳實現(xiàn)SMMS圖床,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • Java實現(xiàn)圖片比對算法

    Java實現(xiàn)圖片比對算法

    這篇文章主要為大家詳細介紹了Java實現(xiàn)圖片比對算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • java語言如何生成plist下載ipa文件

    java語言如何生成plist下載ipa文件

    這篇文章主要介紹了java語言如何生成plist下載ipa文件問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 使用FeignClient設(shè)置動態(tài)Url

    使用FeignClient設(shè)置動態(tài)Url

    這篇文章主要介紹了使用FeignClient設(shè)置動態(tài)Url方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • idea中斷點類型之All和Thread的區(qū)別介紹

    idea中斷點類型之All和Thread的區(qū)別介紹

    使用all模式對于程序中含有多個線程來說,會將多個線程都阻塞在斷點,此時所有的線程都執(zhí)行到此處,在最后一個線程執(zhí)行到此處是會發(fā)生暫停,在這之前的線程會繼續(xù)執(zhí)行到任意位置,本文給大家詳細介紹下idea中斷點類型之All和Thread的區(qū)別,感興趣的朋友一起看看吧
    2022-03-03
  • Spring?WebClient實戰(zhàn)示例

    Spring?WebClient實戰(zhàn)示例

    本文主要介紹了Spring?WebClient實戰(zhàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Springboot下使用Redis管道(pipeline)進行批量操作

    Springboot下使用Redis管道(pipeline)進行批量操作

    本文主要介紹了Spring?boot?下使用Redis管道(pipeline)進行批量操作,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • Java基本語法小白入門級

    Java基本語法小白入門級

    Java基本語法就是指java中的規(guī)則,也是一種語言規(guī)則,規(guī)范,同時也能讓您在后面的學習中避免不必要的一些錯誤和麻煩,是您學好java必修的第一門課程
    2023-05-05
  • Java接口操作(繼承父類并實現(xiàn)多個接口)

    Java接口操作(繼承父類并實現(xiàn)多個接口)

    這篇文章主要介紹了Java接口操作(繼承父類并實現(xiàn)多個接口),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10

最新評論