java excel生成_Java中实现简单的Excel导出

简单介绍一下Java中的Excel文件导出功能(基于HttpServletResponse实现下载)

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

org.apache.poi

poi

3.14

org.apache.poi

poi-ooxml

3.14

编写一个工具类:

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> 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 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;

/**

* @author haozz

* @date 2018/6/6 10:14

* @description

**/

@Controller

@RequestMapping(value = "/index")

public class HelloCtrl extends ExportAbstractUtil{

@RequestMapping(value = "/testExcelOutPut")

@ResponseBody

public void testExcelOutPut(HttpServletResponse response){

//拼接数据start

List> lists = new ArrayList>();

String rows[] = {"year","month","day"};

List rowsTitle = Arrays.asList(rows);

lists.add(rowsTitle);

for(int i = 0; i<=9;i++){

String [] rowss = {"1","2","3"};

List rowssList = Arrays.asList(rowss);

lists.add(rowssList);

}

//拼接数据end

write(response,lists,"导出Excel.xls");

}

}

浏览器输入链接:

即可自动下载测试数据组成的Excel:

59f5bd05ccdabd23da57a8cf78862666.png

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个 Java 导出 Excel 进行换行的示例代码: ```java // 创建一个新的工作簿 Workbook workbook = new XSSFWorkbook(); // 创建一个新的工作表 Sheet sheet = workbook.createSheet("Sheet1"); // 创建一行 Row row = sheet.createRow(0); // 创建一个单元格,并设置文本内容 Cell cell = row.createCell(0); cell.setCellValue("这是一个需要换行的文本,\n这是第二行。"); // 设置单元格样式,使文本自动换行 CellStyle style = workbook.createCellStyle(); style.setWrapText(true); cell.setCellStyle(style); // 将工作簿写入到文件 FileOutputStream outputStream = new FileOutputStream("example.xlsx"); workbook.write(outputStream); outputStream.close(); ``` 在上面的示例代码,我们创建了一个 `XSSFWorkbook` 对象来表示一个新的工作簿,然后创建了一个名为 "Sheet1" 的新工作表,并在第一行第一列添加了一个单元格。 我们在单元格设置了需要换行的文本,并使用 `\n` 字符来表示换行。接着,我们创建了一个 `CellStyle` 对象,并将其设置为自动换行。最后,我们将工作簿写入到一个名为 "example.xlsx" 的文件。 运行代码后,打开生成Excel 文件,可以看到文本已经自动换行了。 需要注意的是,自动换行只在单元格宽度不足以显示所有文本时才会起作用。因此,在实际使用,需要根据文本长度调整单元格宽度,以确保文本能够正确地显示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值