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

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

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

    3187 引用 • 8213 回帖
  • Excel
    30 引用 • 28 回帖

相关帖子

欢迎来到这里!

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

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

推荐标签 标签

  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖 • 1 关注
  • 智能合约

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

    1 引用 • 11 回帖 • 3 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖 • 1 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖 • 1 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 391 关注
  • Git

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

    209 引用 • 358 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 455 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 8 关注
  • 前端

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

    247 引用 • 1348 回帖 • 1 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • RESTful

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

    30 引用 • 114 回帖 • 2 关注
  • Ruby

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

    7 引用 • 31 回帖 • 211 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖 • 2 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    132 引用 • 1114 回帖 • 124 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    186 引用 • 318 回帖 • 302 关注
  • Shell

    Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。

    122 引用 • 74 回帖
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    85 引用 • 139 回帖
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 702 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 63 关注
  • 招聘

    哪里都缺人,哪里都不缺人。

    190 引用 • 1057 回帖 • 1 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 610 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 478 关注
  • DNSPod

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

    6 引用 • 26 回帖 • 510 关注
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 3 关注
  • 导航

    各种网址链接、内容导航。

    40 引用 • 173 回帖
  • Rust

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

    58 引用 • 22 回帖
  • WebClipper

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

    3 引用 • 9 回帖 • 1 关注