java 生成excel文件

2019-03-19  本文已影响0人  Jin110

1)pom文件

        <dependency>
            <groupId>net.sourceforge.jexcelapi</groupId>
            <artifactId>jxl</artifactId>
            <version>2.6.12</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.51</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.17</version>
        </dependency>

2)java文件

import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import javax.servlet.http.HttpServletResponse;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.ss.usermodel.VerticalAlignment;
import org.apache.poi.ss.util.CellRangeAddress;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import jxl.Workbook;
import jxl.format.Colour;
import jxl.write.Label;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

@Controller
@RequestMapping("/public/excel")
public class ExcelController {

    private HSSFWorkbook workBook;

    @RequestMapping(value = { "/", "/index" })
    public String index() {
        return "index";
    }

    @RequestMapping(value = { "/create" })
    public void excelCreate(HttpServletResponse response, String fileName, String sheetList) {
        try {
            response.reset(); // 清除buffer缓存
            // 指定下载的文件名
            String time = new SimpleDateFormat("-yyyyMMddHHmmss").format(new Date());
            response.setHeader("Content-Disposition",
                    "attachment;filename=" + new String(fileName.getBytes("gbk"), "iso8859-1") + time + ".xls");
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Pragma", "no-cache");
            response.setHeader("Cache-Control", "no-cache");
            response.setDateHeader("Expires", 0);
            OutputStream os = response.getOutputStream();
            // 创建工作薄
            WritableWorkbook workbook = Workbook.createWorkbook(os);
            // 标题样式
            WritableFont titleFont = new WritableFont(WritableFont.TIMES, 22, WritableFont.BOLD);// 设置字体种类和黑体显示,字体为Arial,字号大小为10,采用黑体显示
            WritableCellFormat titleFormate = new WritableCellFormat(titleFont);// 生成一个单元格样式控制对象
            titleFormate.setAlignment(jxl.format.Alignment.CENTRE);// 单元格中的内容水平方向居中
            titleFormate.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);// 单元格的内容垂直方向居中
            // 列头部样式
            WritableFont columnFont = new WritableFont(WritableFont.TIMES, 16, WritableFont.BOLD);// 选择字体
            columnFont.setColour(Colour.BLUE);
            WritableCellFormat columnFormat = new WritableCellFormat(columnFont);
            columnFormat.setAlignment(jxl.format.Alignment.CENTRE);// 单元格中的内容水平方向居中
            columnFormat.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);// 单元格的内容垂直方向居中
            // 文本内容样式
            WritableFont bodyFont = new WritableFont(WritableFont.TIMES, 13);
            WritableCellFormat bodyFormate = new WritableCellFormat(bodyFont);
            bodyFormate.setAlignment(jxl.format.Alignment.CENTRE);// 单元格中的内容水平方向居中
            bodyFormate.setVerticalAlignment(jxl.format.VerticalAlignment.CENTRE);// 单元格的内容垂直方向居中
            JSONArray parseArray = JSON.parseArray(sheetList);
            for (int i = 0; i < parseArray.size(); i++) {
                JSONObject jo = parseArray.getJSONObject(i);
                // 获取表名,标题,列的集合,数据集合
                String sheetName = jo.getString("sheetName");
                String titleName = jo.getString("titleName");
                JSONArray columnList = jo.getJSONArray("columnList");
                JSONArray rowList = jo.getJSONArray("rowList");
                // 创建新的一页
                WritableSheet sheet = workbook.createSheet(sheetName, i);
                // 构造标题
                sheet.mergeCells(0, 0, columnList.size() - 1, 0);// 添加合并单元格,第一个参数是起始列,第二个参数是起始行,第三个参数是终止列,第四个参数是终止行
                Label title = new Label(0, 0, titleName, titleFormate);
                sheet.setRowView(0, 800, false);// 设置第一行的高度
                sheet.addCell(title);
                // 构造列头部
                Label label = null;
                for (int j = 0; j < columnList.size(); j++) {
                    JSONObject column = columnList.getJSONObject(j);
                    label = new Label(column.getIntValue("index"), 1, column.getString("title"), columnFormat);
                    sheet.addCell(label);
                }

                // 构造文本内容
                for (int j = 0; j < rowList.size(); j++) {
                    JSONObject row = rowList.getJSONObject(j);
                    for (int k = 0; k < columnList.size(); k++) {
                        JSONObject column = columnList.getJSONObject(k);
                        if (column.getString("index").equals("0") && column.getString("title").equals("序号")) {
                            label = new Label(0, j + 2, (j + 1) + "", bodyFormate);
                        } else {
                            label = new Label(Integer.valueOf(column.getIntValue("index")), j + 2,
                                    row.getString(column.getString("field")), bodyFormate);
                        }
                        sheet.addCell(label);
                    }
                }
            }

            // 把创建的内容写入到输出流中,并关闭输出流
            workbook.write();
            workbook.close();
            os.close();
        } catch (Exception e) {
            e.printStackTrace();
        }

    }

    @RequestMapping(value = { "/excel/create/two" })
    public void excelCreateTwo(HttpServletResponse response, String fileName, String sheetList) {
        try {
            response.reset(); // 清除buffer缓存
            // 指定下载的文件名
            String time = new SimpleDateFormat("-yyyyMMddHHmmss").format(new Date());
            response.setHeader("Content-Disposition",
                    "attachment;filename=" + new String(fileName.getBytes("gbk"), "iso8859-1") + time + ".xls");
            response.setContentType("application/vnd.ms-excel;charset=UTF-8");
            response.setHeader("Pragma", "no-cache");
            response.setHeader("Cache-Control", "no-cache");
            response.setDateHeader("Expires", 0);
            workBook = new HSSFWorkbook();
            // 表头标题样式
            HSSFFont titleFont = workBook.createFont();
            titleFont.setFontName("宋体");
            titleFont.setBold(true);
            titleFont.setFontHeightInPoints((short) 22);// 字体大小
            HSSFCellStyle titleStyle = workBook.createCellStyle();
            titleStyle.setFont(titleFont);
            titleStyle.setAlignment(HorizontalAlignment.CENTER);// 左右居中
            titleStyle.setVerticalAlignment(VerticalAlignment.CENTER);// 上下居中
            titleStyle.setLocked(true);
            // 列头部样式
            HSSFFont columnFont = workBook.createFont();
            columnFont.setFontHeightInPoints((short) 18); // 字体高度
            columnFont.setColor(HSSFFont.COLOR_RED); // 字体颜色
            columnFont.setFontName("黑体"); // 字体
            HSSFCellStyle columnStyle = workBook.createCellStyle();
            columnStyle.setFont(columnFont);
            columnStyle.setAlignment(HorizontalAlignment.CENTER);// 左右居中
            columnStyle.setVerticalAlignment(VerticalAlignment.CENTER);// 上下居中
            // 内容样式
            HSSFFont textFont = workBook.createFont();
            textFont.setFontName("宋体");
            textFont.setFontHeightInPoints((short) 14);// 字体大小
            HSSFCellStyle textStyle = workBook.createCellStyle();
            textStyle.setFont(textFont);
            textStyle.setAlignment(HorizontalAlignment.CENTER);// 左右居中
            textStyle.setVerticalAlignment(VerticalAlignment.CENTER);// 上下居中
            textStyle.setLocked(true);
            JSONArray parseArray = JSON.parseArray(sheetList);
            for (int i = 0; i < parseArray.size(); i++) {
                JSONObject jo = parseArray.getJSONObject(i);
                // 获取表名,标题,列的集合,数据集合
                String sheetName = jo.getString("sheetName");
                String titleName = jo.getString("titleName");
                JSONArray columnList = jo.getJSONArray("columnList");
                JSONArray rowList = jo.getJSONArray("rowList");
                // 创建工作簿
                HSSFSheet sheet = workBook.createSheet();
                // 设置工作簿的名字
                workBook.setSheetName(i, sheetName);
                // 行号,从零开始,每次自动+1
                int rowNomber = -1;
                // 第一行表头标题
                CellRangeAddress cra = new CellRangeAddress(0, 0, 0, columnList.size() - 1);
                sheet.addMergedRegion(cra);
                HSSFRow titleRow = sheet.createRow(++rowNomber);
                titleRow.setHeight((short) 0x349);
                HSSFCell titleCell = titleRow.createCell(0);
                titleCell.setCellStyle(titleStyle);
                titleCell.setCellValue(titleName);
                // 构造列头部
                HSSFRow columnRow = sheet.createRow(++rowNomber);
                for (int j = 0; j < columnList.size(); j++) {
                    JSONObject column = columnList.getJSONObject(j);
                    HSSFCell cell = columnRow.createCell(column.getShort("index"));
                    cell.setCellStyle(columnStyle);
                    cell.setCellValue(column.getString("title"));
                }

                // 构造文本内容
                for (int j = 0; j < rowList.size(); j++) {
                    JSONObject data = rowList.getJSONObject(j);
                    HSSFRow row = sheet.createRow(++rowNomber);
                    for (int k = 0; k < columnList.size(); k++) {
                        JSONObject column = columnList.getJSONObject(k);
                        HSSFCell cell = row.createCell(column.getShort("index"));
                        if (column.getString("index").equals("0") && column.getString("title").equals("序号")) {
                            cell.setCellValue((j + 1) + "");
                        } else {
                            cell.setCellValue(data.getString(column.getString("field")));
                        }
                        cell.setCellStyle(textStyle);
                    }
                }

                // 列宽自适应
                for (int o = 0; o < columnList.size(); o++) {
                    sheet.autoSizeColumn(o);
                }
            }

            OutputStream os = response.getOutputStream();
            workBook.write(os);
            os.flush();
            os.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

3)html文件

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8"/>
    <title>生成Excel文件</title>
</head>
<body>
<h2>生成Excel文件</h2>
<div>
    文件名:<span id="fileName"></span>
</div>
<div>
    <textarea id="sheetList" style="height: 200px; width: 500px;"></textarea>
</div>
<div>
    <button onclick="submitForm()">下载文件</button>
</div>

<script type="text/javascript" src="../static/js/jquery-1.8.3.min.js"></script>
<script type="text/javascript">

    var fileName = "生成的文件名";
    var sheets = [];
    var sheetName = "学生信息表";
    var titleName = "学生基本信息";
    var columnList = [
        {field: 'name', title: '姓名', index: "0"},
        {field: 'sex', title: '性别', index: "1"},
        {field: 'age', title: '年龄', index: "2"},
        {field: 'height', title: '身高', index: "3"},
        {field: 'class', title: '班级', index: "4"}
    ];

    var rowList = [
        {name: '张三', sex: '男', age: "18", height: "170", class: "一班"},
        {name: '李明', sex: '男', age: "17", height: "168", class: "三班"},
        {name: '赵雨', sex: '女', age: "18", height: "166", class: "二班"},
        {name: '天天', sex: '男', age: "19", height: "171", class: "一班"},
        {name: '小雪', sex: '女', age: "18", height: "172", class: "三班"}
    ];

    var sheet = {
        "sheetName": sheetName,
        "titleName": titleName,
        "columnList": columnList,
        "rowList": rowList
    };

    sheets.push(sheet);

    var sheetName1 = "家庭信息表";
    var titleName1 = "学生家庭信息";
    var columnList1 = [
        {field: '', title: '序号', index: "0"},
        {field: 'sname', title: '学生姓名', index: "1"},
        {field: 'fname', title: '父亲姓名', index: "2"},
        {field: 'mname', title: '母亲姓名', index: "3"}
    ];

    var rowList1 = [
        {sname: '张三', fname: '张宇', mname: "李芳"},
        {sname: '李明', fname: '李提行', mname: "王雨"},
        {sname: '赵雨', fname: '赵天明', mname: "周飞"},
        {sname: '天天', fname: '天月', mname: "地明"},
        {sname: '孙雪', fname: '孙空', mname: "白晶"}
    ];

    var sheet1 = {
        "sheetName": sheetName1,
        "titleName": titleName1,
        "columnList": columnList1,
        "rowList": rowList1
    };

    sheets.push(sheet1);
    var sheetList = JSON.stringify(sheets);
    $("#fileName").html(fileName);
    $("#sheetList").html(sheetList);
    function submitForm() {
        var forme = document.createElement("form");
        document.body.appendChild(forme);
        forme.method = 'post';
        forme.action = "/excel/create/two";
        var fname = document.createElement("input");
        fname.setAttribute("name", "fileName");
        fname.setAttribute("type", "hidden");
        fname.setAttribute("value", fileName);
        forme.appendChild(fname);
        var slist = document.createElement("input");
        slist.setAttribute("name", "sheetList");
        slist.setAttribute("type", "hidden");
        slist.setAttribute("value", sheetList);
        forme.appendChild(slist);
        forme.submit();
    }
</script>
</body>
</html>

3)新的最简单的测试文件

package com.efangtec.common.utils;

import java.io.File;
import java.io.FileOutputStream;
import java.lang.management.ManagementFactory;
import java.lang.management.MemoryUsage;
import java.util.Date;

import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

// 库存报表导出帮助类
public class StockExportUtil {

    public static void main(String[] args) {
        String[] data = { "73982", "1", "NH", "1", "2018122510", "2", "0", "0", "0", "12233", "0", "楼层组件优化", "0" };

        Date startTime = new Date();
        MemoryUsage startMemory = ManagementFactory.getMemoryMXBean().getHeapMemoryUsage();

        // 创建工作薄
        XSSFWorkbook workbook = new XSSFWorkbook();
        // 创建工作表
        XSSFSheet sheet = workbook.createSheet("sheet1");

        // 设置数据
        for (int row = 0; row < 50; row++) {
            XSSFRow sheetRow = sheet.createRow(row);
            for (int column = 0; column < data.length; column++) {
                sheetRow.createCell(column).setCellValue(data[column]);
            }
        }

        // 写入文件
        try {
            workbook.write(new FileOutputStream(new File("/Users/jinguohui/Desktop/book/excel.xlsx")));
            workbook.close();
        } catch (Exception ex) {
            System.out.println(ex.getMessage());
        }
        Date endTime = new Date();
        MemoryUsage endMemory = ManagementFactory.getMemoryMXBean().getHeapMemoryUsage();
        System.out.println("Cost time(ms): " + (endTime.getTime() - startTime.getTime()));
        System.out.println("Cost memory(): " + (endMemory.getUsed() - startMemory.getUsed()));

        System.out.println("Hello World!");

    }
}

上一篇 下一篇

猜你喜欢

热点阅读