91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在Java中實現導出Excel

發布時間:2021-05-27 17:46:10 來源:億速云 閱讀:176 作者:Leah 欄目:編程語言

本篇文章為大家展示了怎么在Java中實現導出Excel,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

首先,引入需要依賴的jar包:

<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi</artifactId>
 <version>3.14</version>
</dependency>
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi-ooxml</artifactId>
 <version>3.14</version>
</dependency>

編寫一個工具類:

package exceloutput;
import org.apache.commons.lang3.StringUtils;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.streaming.SXSSFSheet;
import org.apache.poi.xssf.streaming.SXSSFWorkbook;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.List;
import java.util.UUID;
/**
 * @author haozz
 * @date 2018/6/6 9:57
 * @description excel導出抽象工具類
 **/
public abstract class ExportAbstractUtil {
  public void write(HttpServletResponse response, Workbook workbook){
    String fileName = UUID.randomUUID().toString()+".xls";
    pwrite(response,workbook,fileName);
  }
  public void write(HttpServletResponse response,Workbook workbook,String fileName){
    if(StringUtils.isEmpty(fileName)){
      fileName = UUID.randomUUID().toString()+".xls";
    }
    pwrite(response,workbook,fileName);
  }
  public void write(HttpServletResponse response, List<List<String>> lists,String fileName){
    if(StringUtils.isEmpty(fileName)){
      fileName = UUID.randomUUID().toString()+".xls";
    }
    SXSSFWorkbook workbook = new SXSSFWorkbook(lists.size());
    SXSSFSheet sheet = workbook.createSheet(fileName.substring(0,fileName.indexOf(".xls")));
    Integer rowIndex = 0;
    Row row = null;
    Cell cell = null;
    for(List<String> rowData: lists ){
      Integer columnIndex = 0;
      row = sheet.createRow(rowIndex++);
      for(String columnVal:rowData){
        cell = row.createCell(columnIndex++);
        cell.setCellValue(columnVal);
      }
    }
    pwrite(response,workbook,fileName);
  }
  private void pwrite(HttpServletResponse response,Workbook workbook,String fileName){
    response.setCharacterEncoding("UTF-8");
    response.setContentType("application/vnd.ms-excel;charset=UTF-8");
    try {
      response.addHeader("Content-Disposition", "attachment; filename="+new String(fileName.getBytes("UTF-8"),"ISO8859-1"));
    } catch (UnsupportedEncodingException e) {
      e.printStackTrace();
      fileName= UUID.randomUUID().toString()+".xls";
      response.addHeader("Content-Disposition", "attachment; filename="+fileName);
    }
    try {
      workbook.write(response.getOutputStream());
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

有了這個工具類就可以實現Excel導出了,代碼不難,這里就不多解釋了。

在SpringBoot項目中編寫一個導出Excel的Controller,并繼承上面的ExportAbstractUtil,給出一個接口用作測試:

package com.csdn.myboot.controller;
import com.csdn.myboot.utils.ExportAbstractUtil;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;

@Controller
@RequestMapping(value = "/index")
public class HelloCtrl extends ExportAbstractUtil{
  @RequestMapping(value = "/testExcelOutPut")
  @ResponseBody
  public void testExcelOutPut(HttpServletResponse response){
    //拼接數據start
    List<List<String>> lists = new ArrayList<List<String>>();
    String rows[] = {"year","month","day"};
    List<String> rowsTitle = Arrays.asList(rows);
    lists.add(rowsTitle);
    for(int i = 0; i<=9;i++){
      String [] rowss = {"1","2","3"};
      List<String> rowssList = Arrays.asList(rowss);
      lists.add(rowssList);
    }
    //拼接數據end
    write(response,lists,"導出Excel.xls");
  }
}

上述內容就是怎么在Java中實現導出Excel,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和田县| 丰都县| 贵定县| 茂名市| 宁晋县| 玛沁县| 阿克苏市| 沽源县| 贵定县| 柳州市| 南开区| 南召县| 毕节市| 宝坻区| 乌兰浩特市| 彭阳县| 营口市| 兴山县| 阳西县| 象州县| 亚东县| 开江县| 广南县| 盐源县| 南召县| 丹阳市| 青龙| 岗巴县| 米易县| 禹城市| 二连浩特市| 扬中市| 涿鹿县| 哈密市| 松滋市| 建阳市| 湟中县| 上饶市| 兰州市| 仁布县| 游戏|