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

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

引入依赖包,代码可直接运行 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
    23 引用 • 21 回帖
  • Java

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

    3190 引用 • 8214 回帖
  • Excel
    30 引用 • 28 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2036 回帖
  • Eclipse

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

    75 引用 • 258 回帖 • 624 关注
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 481 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    5 引用 • 107 回帖 • 1 关注
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖 • 2 关注
  • Thymeleaf

    Thymeleaf 是一款用于渲染 XML/XHTML/HTML5 内容的模板引擎。类似 Velocity、 FreeMarker 等,它也可以轻易的与 Spring 等 Web 框架进行集成作为 Web 应用的模板引擎。与其它模板引擎相比,Thymeleaf 最大的特点是能够直接在浏览器中打开并正确显示模板页面,而不需要启动整个 Web 应用。

    11 引用 • 19 回帖 • 367 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 344 回帖
  • WebClipper

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

    3 引用 • 9 回帖 • 3 关注
  • 小说

    小说是以刻画人物形象为中心,通过完整的故事情节和环境描写来反映社会生活的文学体裁。

    28 引用 • 108 回帖
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 142 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 6 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 53 关注
  • PostgreSQL

    PostgreSQL 是一款功能强大的企业级数据库系统,在 BSD 开源许可证下发布。

    22 引用 • 22 回帖 • 6 关注
  • Ruby

    Ruby 是一种开源的面向对象程序设计的服务器端脚本语言,在 20 世纪 90 年代中期由日本的松本行弘(まつもとゆきひろ/Yukihiro Matsumoto)设计并开发。在 Ruby 社区,松本也被称为马茨(Matz)。

    7 引用 • 31 回帖 • 220 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    288 引用 • 4485 回帖 • 662 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 1 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 560 关注
  • danl
    150 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 349 关注
  • HTML

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

    107 引用 • 295 回帖
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1395 回帖
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    158 引用 • 3801 回帖
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Vue.js

    Vue.js(读音 /vju ː/,类似于 view)是一个构建数据驱动的 Web 界面库。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。

    265 引用 • 666 回帖 • 2 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 430 回帖