导出 excel 多 sheet 且有跨列及背景色样式

本贴最后更新于 1829 天前,其中的信息可能已经时移世易

引入依赖包,代码可直接运行 main 方法看效果。希望能帮到你

import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress;

import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;

/**
 * 导出excel多sheet且有跨列及背景色样式
 *
 * @author Stone
 */
public class ExportExcelUtil {

    /**
     * 导出多sheet格式的excel
     *
     * @param fileSavePath 导出文件保存路径
     * @param workbook     工作薄对象
     * @param sheetIndex   sheet位置,0表示第一个表格中的第一个sheet
     * @param sheetName    sheet名称
     * @param sheetTitle   sheet标题
     * @param headers      sheet各列标题头
     * @param data         sheet数据集
     * @param weekbottomsW sheet底部合计行(外部)
     * @param weekbottomsN sheet底部合计行(内部)
     */
    public void exportExcel(String fileSavePath, HSSFWorkbook workbook, int sheetIndex, String sheetName, String sheetTitle, String[] headers, List<List<String>> data, String[] weekbottomsW, String[] weekbottomsN) {
        try {
            //创建工作薄
            HSSFSheet sheet = workbook.createSheet();
            //设置sheet位置及名称
            workbook.setSheetName(sheetIndex, sheetName);
            //设置工作薄默认列宽度,单位:字节
            sheet.setDefaultColumnWidth((short) 23);
            //创建sheet页公共标题行及样式
            Row rowTitle = sheet.createRow(0);
            //标题字体
            Font fontTitle = workbook.createFont();
            //字体字号
            fontTitle.setFontHeightInPoints((short) 11);
            //是否加粗
            fontTitle.setBold(true);
            //标题样式
            CellStyle styleTitle = workbook.createCellStyle();
            styleTitle.setBorderBottom(BorderStyle.THIN);
            styleTitle.setBorderLeft(BorderStyle.THIN);
            styleTitle.setBorderRight(BorderStyle.THIN);
            styleTitle.setBorderTop(BorderStyle.THIN);
            styleTitle.setAlignment(HorizontalAlignment.CENTER);
            styleTitle.setFont(fontTitle);
            //标题所在行号0标识当前sheet页第1行
            Cell cellTitle = rowTitle.createCell(0);
            //应用样式
            cellTitle.setCellStyle(styleTitle);
            //标题行跨列设置
            sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, headers.length - 1));
            cellTitle.setCellValue(sheetTitle);

            //创建表格各列标题行
            Row rowHeade = sheet.createRow(1);
            for (int i = 0; i < headers.length; i++) {
                Cell cellHeader = rowHeade.createCell((short) i);
                cellHeader.setCellStyle(styleTitle);
                HSSFRichTextString text = new HSSFRichTextString(headers[i]);
                cellHeader.setCellValue(text.toString());
            }

            //遍历数据集合,创建数据行
            if (data != null) {
                //从第3行开始写入数据行
                int index = 2;

                //临时列内容,用于判断背景色是否应发生变化
                String code = "";
                //是否设置背景色
                boolean isColor = true;

                for (List<String> sheetData : data) {
                    //创建数据行
                    Row rowData = sheet.createRow(index);

                    String entName = sheetData.get(0);
                    if(StringUtil.isNotEmpty(code) && !entName.equals(code)){
                        if(isColor){
                            isColor= false;
                        }else{
                            isColor= true;
                        }
                    }
                    code = entName;

                    //从第1列开始写入数据列
                    int cellIndex = 0;
                    for (String sd : sheetData) {
                        Cell cellData = rowData.createCell((short) cellIndex);
                        if(isColor){
                            cellData.setCellStyle(getCellStyleBlue(workbook));
                        }else{
                            cellData.setCellStyle(getCellStyleWhite(workbook));
                        }
                        cellData.setCellValue(sd.toString());
                        cellIndex++;
                    }
                    index++;
                }
            }

            //创建表格底部计算行(外部)
            Row bottomsW = sheet.createRow(data.size() + 2);
            Cell cellBottom = null;
            for (int i = 0; i < weekbottomsW.length; i++) {
                cellBottom = bottomsW.createCell((short) i);
                cellBottom.setCellStyle(styleTitle);
                HSSFRichTextString text = new HSSFRichTextString(weekbottomsW[i]);
                if (i == 0) {
                    sheet.addMergedRegion(new CellRangeAddress(data.size() + 2, data.size() + 2, 0, 1));
                }
                cellBottom.setCellValue(text.toString());
            }
            //创建表格底部计算行(内部)
            Row bottomsN = sheet.createRow(data.size() + 3);
            for (int i = 0; i < weekbottomsN.length; i++) {
                cellBottom = bottomsN.createCell((short) i);
                cellBottom.setCellStyle(styleTitle);
                HSSFRichTextString text = new HSSFRichTextString(weekbottomsN[i]);
                if (i == 0) {
                    sheet.addMergedRegion(new CellRangeAddress(data.size() + 3, data.size() + 3, 0, 1));
                }
                cellBottom.setCellValue(text.toString());
            }

            //初始化文件流对象
            OutputStream file = new FileOutputStream(fileSavePath);
            //将数据写入工作薄
            workbook.write(file);
            //关闭文件流
            file.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public CellStyle getCellStyleBlue (HSSFWorkbook workbook){
        //数据行字体设置
        Font fontData = workbook.createFont();
        fontData.setFontHeightInPoints((short) 11);
        //数据行样式设置
        CellStyle cellStyle = workbook.createCellStyle();
        //背景色
        cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        cellStyle.setBorderBottom(BorderStyle.THIN);
        cellStyle.setBorderLeft(BorderStyle.THIN);
        cellStyle.setBorderRight(BorderStyle.THIN);
        cellStyle.setBorderTop(BorderStyle.THIN);
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        cellStyle.setFont(fontData);
        //设置背景色为浅蓝色
        cellStyle.setFillForegroundColor(IndexedColors.LIGHT_CORNFLOWER_BLUE.getIndex());
        return cellStyle;
    }

    public CellStyle getCellStyleWhite (HSSFWorkbook workbook){
        //数据行字体设置
        Font fontData = workbook.createFont();
        fontData.setFontHeightInPoints((short) 11);
        //数据行样式设置
        CellStyle cellStyle = workbook.createCellStyle();
        //背景色
        cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        cellStyle.setBorderBottom(BorderStyle.THIN);
        cellStyle.setBorderLeft(BorderStyle.THIN);
        cellStyle.setBorderRight(BorderStyle.THIN);
        cellStyle.setBorderTop(BorderStyle.THIN);
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        cellStyle.setFont(fontData);
        cellStyle.setFillForegroundColor(IndexedColors.WHITE1.getIndex());
        return cellStyle;
    }

    public static void main(String[] args) {
        try {
            //导出文件名
            String fileName = new StringBuilder("导出Excel文件名").append(".xls").toString();
            List<List<String>> weekSheet1Data = new ArrayList<List<String>>();
            String weekSheet1bottomsWSumA = "-";
            String weekSheet1bottomsWSumB = "-";
            String weekSheet1bottomsWSumC = "-";
            String weekSheet1bottomsNSumA = "-";
            String weekSheet1bottomsNSumB = "-";
            String weekSheet1bottomsNSumC = "-";
            String[] weekSheet1bottomsW = {"合计(外部)", "", weekSheet1bottomsWSumA, weekSheet1bottomsWSumB, weekSheet1bottomsWSumC};
            String[] weekSheet1bottomsN = {"合计(内部)", "", weekSheet1bottomsNSumA, weekSheet1bottomsNSumB, weekSheet1bottomsNSumC};
            List<List<String>> weekSheet2Data = new ArrayList<List<String>>();
            String weekSheet2bottomsWSumA = "-";
            String weekSheet2bottomsWSumB = "-";
            String weekSheet2bottomsWSumC = "-";
            String weekSheet2bottomsNSumA = "-";
            String weekSheet2bottomsNSumB = "-";
            String weekSheet2bottomsNSumC = "-";
            String[] weekSheet2bottomsW = {"合计(外部)", "", weekSheet2bottomsWSumA, weekSheet2bottomsWSumB, weekSheet2bottomsWSumC};
            String[] weekSheet2bottomsN = {"合计(内部)", "", weekSheet2bottomsNSumA, weekSheet2bottomsNSumB, weekSheet2bottomsNSumC};
            List<List<String>> weekSheet3Data = new ArrayList<List<String>>();
            String weekSheet3bottomsWSumA = "-";
            String weekSheet3bottomsWSumB = "-";
            String weekSheet3bottomsWSumC = "-";
            String weekSheet3bottomsNSumA = "-";
            String weekSheet3bottomsNSumB = "-";
            String weekSheet3bottomsNSumC = "-";
            String[] weekSheet3bottomsW = {"合计(外部)", "", weekSheet3bottomsWSumA, weekSheet3bottomsWSumB, weekSheet3bottomsWSumC};
            String[] weekSheet3bottomsN = {"合计(内部)", "", weekSheet3bottomsNSumA, weekSheet3bottomsNSumB, weekSheet3bottomsNSumC};

            List rowData1 = new ArrayList<Object>() {{
                this.add("北京市");
                this.add("某公司");
                this.add("1234");
                this.add("567");
                this.add("89");
            }};
            List rowData2 = new ArrayList<Object>() {{
                this.add("北京市");
                this.add("某某公司");
                this.add("2334");
                this.add("677");
                this.add("90");
            }};
            List rowData3 = new ArrayList<Object>() {{
                this.add("河北省");
                this.add("X公司");
                this.add("8934");
                this.add("547");
                this.add("69");
            }};
            List rowData4 = new ArrayList<Object>() {{
                this.add("河北省");
                this.add("XX公司");
                this.add("3934");
                this.add("647");
                this.add("93");
            }};
            List rowData5 = new ArrayList<Object>() {{
                this.add("山东省");
                this.add("公司名称");
                this.add("5234");
                this.add("787");
                this.add("83");
            }};
            List rowData6 = new ArrayList<Object>() {{
                this.add("陕西省");
                this.add("公司公司");
                this.add("9034");
                this.add("737");
                this.add("59");
            }};
            List rowData7 = new ArrayList<Object>() {{
                this.add("陕西省");
                this.add("某有限公司");
                this.add("8834");
                this.add("667");
                this.add("73");
            }};
            List rowData8 = new ArrayList<Object>() {{
                this.add("青海省");
                this.add("0.0有限责任公司");
                this.add("7634");
                this.add("337");
                this.add("82");
            }};
            List rowData9 = new ArrayList<Object>() {{
                this.add("青海省");
                this.add("青海X有限责任公司");
                this.add("6334");
                this.add("737");
                this.add("66");
            }};

            weekSheet1Data.add(rowData1);
            weekSheet1Data.add(rowData2);
            weekSheet1Data.add(rowData3);
            weekSheet1Data.add(rowData4);
            weekSheet1Data.add(rowData5);
            weekSheet1Data.add(rowData6);
            weekSheet1Data.add(rowData7);
            weekSheet1Data.add(rowData8);
            weekSheet1Data.add(rowData9);

            weekSheet2Data.add(rowData1);
            weekSheet2Data.add(rowData2);
            weekSheet2Data.add(rowData3);
            weekSheet2Data.add(rowData4);
            weekSheet2Data.add(rowData5);
            weekSheet2Data.add(rowData6);
            weekSheet2Data.add(rowData7);
            weekSheet2Data.add(rowData8);
            weekSheet2Data.add(rowData9);

            weekSheet3Data.add(rowData1);
            weekSheet3Data.add(rowData2);
            weekSheet3Data.add(rowData3);
            weekSheet3Data.add(rowData4);
            weekSheet3Data.add(rowData5);
            weekSheet3Data.add(rowData6);
            weekSheet3Data.add(rowData7);
            weekSheet3Data.add(rowData8);
            weekSheet3Data.add(rowData9);


            //导出文件保存路径
            String fileSavePath = new StringBuilder("D:\\").append(fileName).toString();
            //工作薄标题头,假如有5列
            String[] weekHeaders = {"省", "公司", "Num1", "Num2", "Num3"};

            ExportExcelUtil util = new ExportExcelUtil();
            HSSFWorkbook workbook = new HSSFWorkbook();
            //假如需要写入三个Sheet工作薄
            util.exportExcel(fileSavePath, workbook, 0, "一区", "统计", weekHeaders, weekSheet1Data, weekSheet1bottomsW, weekSheet1bottomsN);
            util.exportExcel(fileSavePath, workbook, 1, "二区", "统计", weekHeaders, weekSheet2Data, weekSheet2bottomsW, weekSheet2bottomsN);
            util.exportExcel(fileSavePath, workbook, 2, "三区", "统计", weekHeaders, weekSheet3Data, weekSheet3bottomsW, weekSheet3bottomsN);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

}

英雄留步!走过路过不要错过,既然来了就恭请加入 平等 • 自由 • 奔放黑客派社区,一起学习,相互分享,共同进步吧 😄
注册邀请链接:https://hacpai.com/register?r=Stone

  • POI
    22 引用 • 21 回帖
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3172 引用 • 8209 回帖
  • Excel
    30 引用 • 28 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    106 引用 • 295 回帖 • 1 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖
  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    676 引用 • 535 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    130 引用 • 793 回帖
  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 748 关注
  • 负能量

    上帝为你关上了一扇门,然后就去睡觉了....努力不一定能成功,但不努力一定很轻松 (° ー °〃)

    88 引用 • 1235 回帖 • 413 关注
  • 服务

    提供一个服务绝不仅仅是简单的把硬件和软件累加在一起,它包括了服务的可靠性、服务的标准化、以及对服务的监控、维护、技术支持等。

    41 引用 • 24 回帖 • 1 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    132 引用 • 188 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    165 引用 • 594 回帖
  • Dubbo

    Dubbo 是一个分布式服务框架,致力于提供高性能和透明化的 RPC 远程服务调用方案,是 [阿里巴巴] SOA 服务化治理方案的核心框架,每天为 2,000+ 个服务提供 3,000,000,000+ 次访问量支持,并被广泛应用于阿里巴巴集团的各成员站点。

    60 引用 • 82 回帖 • 593 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 1 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    497 引用 • 1387 回帖 • 298 关注
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 50 关注
  • Gitea

    Gitea 是一个开源社区驱动的轻量级代码托管解决方案,后端采用 Go 编写,采用 MIT 许可证。

    4 引用 • 16 回帖 • 5 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 441 关注
  • RESTful

    一种软件架构设计风格而不是标准,提供了一组设计原则和约束条件,主要用于客户端和服务器交互类的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

    30 引用 • 114 回帖 • 4 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 61 关注
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖 • 100 关注
  • abitmean

    有点意思就行了

    27 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 9 关注
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 1 关注
  • OpenShift

    红帽提供的 PaaS 云,支持多种编程语言,为开发人员提供了更为灵活的框架、存储选择。

    14 引用 • 20 回帖 • 619 关注
  • 笔记

    好记性不如烂笔头。

    308 引用 • 793 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 249 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    75 引用 • 258 回帖 • 621 关注