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

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

引入依赖包,代码可直接运行 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 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3074 引用 • 8189 回帖 • 361 关注
  • Excel
    28 引用 • 27 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    157 引用 • 797 回帖
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    56 引用 • 282 回帖
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 65 关注
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1347 回帖 • 1 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 6 关注
  • RYMCU

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

    4 引用 • 6 回帖 • 9 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖
  • Love2D

    Love2D 是一个开源的, 跨平台的 2D 游戏引擎。使用纯 Lua 脚本来进行游戏开发。目前支持的平台有 Windows, Mac OS X, Linux, Android 和 iOS。

    14 引用 • 53 回帖 • 460 关注
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台,“下一代的社区系统,为未来而构建”。

    521 引用 • 4570 回帖 • 638 关注
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 561 关注
  • GitBook

    GitBook 使您的团队可以轻松编写和维护高质量的文档。 分享知识,提高团队的工作效率,让用户满意。

    3 引用 • 8 回帖
  • CodeMirror
    1 引用 • 2 回帖 • 46 关注
  • JWT

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

    19 引用 • 15 回帖 • 4 关注
  • DNSPod

    DNSPod 建立于 2006 年 3 月份,是一款免费智能 DNS 产品。 DNSPod 可以为同时有电信、网通、教育网服务器的网站提供智能的解析,让电信用户访问电信的服务器,网通的用户访问网通的服务器,教育网的用户访问教育网的服务器,达到互联互通的效果。

    6 引用 • 26 回帖 • 499 关注
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 618 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    19 引用 • 31 回帖
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 594 关注
  • NGINX

    NGINX 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 NGINX 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本 0.1.0 发布于 2004 年 10 月 4 日。

    297 引用 • 539 回帖 • 302 关注
  • OpenShift

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

    14 引用 • 20 回帖 • 585 关注
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    28 引用 • 98 回帖 • 664 关注
  • App

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

    90 引用 • 373 回帖
  • 京东

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

    14 引用 • 102 回帖 • 488 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    28 引用 • 209 回帖 • 551 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    70 引用 • 527 回帖 • 598 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 6 关注
  • 数据库

    据说 99% 的性能瓶颈都在数据库。

    324 引用 • 602 回帖
  • MongoDB

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

    87 引用 • 59 回帖