编程技术是改变世界的力量。
本站
当前位置:网站首页 > 后端语言 > 正文

Java,POI,根据模板导出Excel文件(xls和xlsx),Sheet样式设置

gowuye 2024-04-04 11:56 2 浏览 0 评论

Apache POI

POI为【Poor Obfuscation Implementation】的首字母缩写,意为【可怜的模糊实现】。Java程序对Microsoft Office格式档案读和写的功能。

POI是创建和维护操作各种符合Office Open XML(OOXML)标准和微软的OLE 2复合文档格式(OLE2)的Java API。可以使用Java读取和创建、修改MS Excel文件,还可以使用Java读取和创建MS Word和MSPowerPoint文件,POI提供Java操作Excel解决方案(适用于Excel97-2008)。

Web下载功能的关注点:

具体代码:

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>3.16</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>3.16</version>
</dependency>
<dependency>
    <groupId>net.sourceforge.jexcelapi</groupId>
    <artifactId>jxl</artifactId>
    <version>2.6.10</version>
</dependency>
//============================================================================================//
//=====根据模板,使用poi组件导出exeel文件
//============================================================================================//
try {
    ClassPathResource classPathResource = new ClassPathResource("template/费用明细模板20201202.xls");
    InputStream input = classPathResource.getInputStream();
    HSSFWorkbook hssfWorkbook = new HSSFWorkbook(input);
    HSSFSheet hssFSheet = hssfWorkbook.getSheetAt(0);
    this.fillUserBillEntryListForSheet(hssfWorkbook, hssFSheet, userBillEntryList);
    String fileName = "费用明细_" + DateUtil.Y_M_DAY.format(new Date());
    fileName = URLEncoder.encode(fileName, "UTF-8");
    response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xls");
    response.setContentType("application/octet-stream");
    hssfWorkbook.write(response.getOutputStream());
} catch (IOException e) {
    e.printStackTrace();
}
//============================================================================================//
//=====The end
//============================================================================================//

读取模板(.xls)设置样式并输出

package com.what21.poi;

import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.usermodel.BorderStyle;
import org.apache.poi.ss.usermodel.FillPatternType;
import org.apache.poi.ss.usermodel.HorizontalAlignment;

import java.io.*;

public class PoiExcel2XlsTest {

    public static void main(String[] args) throws IOException {
        String fileStr = "d://费用明细模板20201202.xls";
        InputStream input = new FileInputStream(fileStr);
        HSSFWorkbook hssfWorkbook = new HSSFWorkbook(input);
        HSSFSheet hssFSheet = hssfWorkbook.getSheetAt(0);
        //设置第3行
        HSSFRow row3 = hssFSheet.createRow(2);
        HSSFCell cell31 = row3.createCell(0);
        cell31.setCellStyle(getCellStyle(hssfWorkbook));
        cell31.setCellValue("11111111");
        HSSFCell cell32 = row3.createCell(1);
        cell32.setCellStyle(getCellStyle(hssfWorkbook));
        cell32.setCellValue("22222222");
        HSSFCell cell33 = row3.createCell(2);
        cell33.setCellStyle(getCellStyle(hssfWorkbook));
        cell33.setCellValue("33333333");
        HSSFCell cell34 = row3.createCell(3);
        cell34.setCellStyle(getCellStyle(hssfWorkbook));
        cell34.setCellValue("44444444");
        HSSFCell cell35 = row3.createCell(4);
        cell35.setCellStyle(getCellStyle(hssfWorkbook));
        cell35.setCellValue("55555555");
        //设置第4行
        HSSFRow row4 = hssFSheet.createRow(3);
        row4.createCell(0).setCellValue("11111111");
        row4.createCell(1).setCellValue("22222222");
        row4.createCell(2).setCellValue("33333333");
        row4.createCell(3).setCellValue("44444444");
        row4.createCell(4).setCellValue("55555555");

        String exportFileStr = "d://费用明细模板20201202.1.xls";
        hssfWorkbook.write(new FileOutputStream(new File(exportFileStr)));

    }

    /**
     * @param hssfWorkbook
     * @return
     */
    public static HSSFCellStyle getCellStyle(HSSFWorkbook hssfWorkbook) {
        // 样式设置
        HSSFCellStyle cellStyle = hssfWorkbook.createCellStyle();
        // =======================================================================//
        cellStyle.setBorderBottom(BorderStyle.THIN);//设置下边框
        cellStyle.setBorderLeft(BorderStyle.THIN);//设置左边框
        cellStyle.setBorderRight(BorderStyle.THIN);//设置右边框
        cellStyle.setBorderTop(BorderStyle.THIN);//设置上边框
        // =======================================================================//
        // 设置边框颜色
        cellStyle.setBottomBorderColor((short) 1);
        // 设置每个单元格的文字居中
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        // =======================================================================//
        //通过HSSFWorkbook创建一个HSSFFont
        HSSFFont font = hssfWorkbook.createFont();
        //设置一个字体的颜色
        //2表示红色
        //3表示绿色
        //4表示蓝色
        //5表示黄色
        //6表示紫色
        //7表示亮蓝色
        //8表示黑色
        //9表示白色
        font.setColor((short) 8);
        //设置字体的风格:仿宋_GB2312、黑体
        font.setFontName("黑体");
        //设置一个字体的大小,此数值的取值与Excel中的字体大小取值一样
        font.setFontHeightInPoints((short) 9);
        //粗体显示
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        //把该字体应用到当前的样式
        cellStyle.setFont(font);
        // =======================================================================//
        // 设置自动换行
        cellStyle.setWrapText(true);
        // =======================================================================//
        // 设置背景色
        cellStyle.setFillForegroundColor((short) 7);
        cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        // =======================================================================//
        return cellStyle;
    }

}

读取模板(.xlsx)设置样式并输出

package com.what21.poi;

import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.ss.usermodel.BorderStyle;
import org.apache.poi.ss.usermodel.FillPatternType;
import org.apache.poi.ss.usermodel.HorizontalAlignment;
import org.apache.poi.xssf.usermodel.*;

import java.io.*;

public class PoiExcel2XlsxTest {

    public static void main(String[] args) throws IOException {
        String fileStr = "d://费用明细模板20201202.xlsx";
        InputStream input = new FileInputStream(fileStr);
        XSSFWorkbook xssfWorkbook = new XSSFWorkbook(input);
        XSSFSheet xssFSheet = xssfWorkbook.getSheetAt(0);
        //设置第3行
        XSSFRow row3 = xssFSheet.getRow(2);
        XSSFCell cell31 = row3.createCell(0);
        cell31.setCellStyle(getCellStyle(xssfWorkbook));
        cell31.setCellValue("11111111");
        XSSFCell cell32 = row3.createCell(1);
        cell32.setCellStyle(getCellStyle(xssfWorkbook));
        cell32.setCellValue("22222222");
        XSSFCell cell33 = row3.createCell(2);
        cell33.setCellStyle(getCellStyle(xssfWorkbook));
        cell33.setCellValue("33333333");
        XSSFCell cell34 = row3.createCell(3);
        cell34.setCellStyle(getCellStyle(xssfWorkbook));
        cell34.setCellValue("44444444");
        XSSFCell cell35 = row3.createCell(4);
        cell35.setCellStyle(getCellStyle(xssfWorkbook));
        cell35.setCellValue("55555555");
        //设置第4行
        XSSFRow row4 = xssFSheet.getRow(3);
        row4.createCell(0).setCellValue("11111111");
        row4.createCell(1).setCellValue("22222222");
        row4.createCell(2).setCellValue("33333333");
        row4.createCell(3).setCellValue("44444444");
        row4.createCell(4).setCellValue("55555555");
        String exportFileStr = "d://费用明细模板20201202.1.xlsx";
        xssfWorkbook.write(new FileOutputStream(new File(exportFileStr)));

    }

    /**
     * @param xssFWorkbook
     * @return
     */
    public static XSSFCellStyle getCellStyle(XSSFWorkbook xssFWorkbook) {
        // 样式设置
        XSSFCellStyle cellStyle = xssFWorkbook.createCellStyle();
        // =======================================================================//
        cellStyle.setBorderBottom(BorderStyle.THIN);//设置下边框
        cellStyle.setBorderLeft(BorderStyle.THIN);//设置左边框
        cellStyle.setBorderRight(BorderStyle.THIN);//设置右边框
        cellStyle.setBorderTop(BorderStyle.THIN);//设置上边框
        // =======================================================================//
        // 设置边框颜色
        cellStyle.setBottomBorderColor((short) 1);
        // 设置每个单元格的文字居中
        cellStyle.setAlignment(HorizontalAlignment.CENTER);
        // =======================================================================//
        //通过XSSFWorkbook创建一个HSSFFont
        XSSFFont font = xssFWorkbook.createFont();
        //设置一个字体的颜色
        //2表示红色
        //3表示绿色
        //4表示蓝色
        //5表示黄色
        //6表示紫色
        //7表示亮蓝色
        //8表示黑色
        //9表示白色
        font.setColor((short) 8);
        //设置字体的风格:仿宋_GB2312、黑体
        font.setFontName("黑体");
        //设置一个字体的大小,此数值的取值与Excel中的字体大小取值一样
        font.setFontHeightInPoints((short) 9);
        //粗体显示
        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
        //把该字体应用到当前的样式
        cellStyle.setFont(font);
        // =======================================================================//
        // 设置自动换行
        cellStyle.setWrapText(true);
        // =======================================================================//
        // 设置背景色
        cellStyle.setFillForegroundColor((short) 7);
        cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
        // =======================================================================//
        return cellStyle;
    }

}

相关推荐

PHPMailer远程命令执行漏洞分析

摘要:PHPMailer是一个强大的PHP编写的邮件发送类,但近日被爆出远程命令执行漏洞,该漏洞实际上是什么,有何种影响,本文对该漏洞进行了分析及验证方法,并给出防护方案。0x00漏洞概要PHPMa...

「安全漏洞」DedeCMS-5.8.1 SSTI模板注入导致RCE

漏洞类型SSTIRCE利用条件影响范围应用漏洞概述2021年9月30日,国外安全研究人员StevenSeeley披露了最新的DedeCMS版本中存在的一处SQL注入漏洞以及一处SSTI导致的RCE...

回顾使用PHP原生发送电子邮件(终)文件附件

FileAttachments文件附件Fileattachmentsworkjustlikemixedemail,exceptthatadifferentcontenttyp...

php-fpm.conf &amp; php.ini 安全优化实践

0x01关于php其历史相对已经比较久远了,这里也就不废话了,属弱类型中一种解释型语言除了web开发以及写些简单的exp,暂未发现其它牛逼用途,暂以中小型web站点开发为主另外,低版本的php自身...

linux 安全配置 ossec 开源检测

linux安全配置ossec开源检测一:介绍主要功能有日志分析、完整性检查、rootkit检测、基于时间的警报和主动响应。除了具有入侵检测系统功能外,它还一般被用在SEM/SIM(安全事件管理(...

PHP使用PHPMailer发送验证码邮件的方法与调用逻辑

首先我们需要下载PHPMailer:https://github.com/PHPMailer/PHPMailer一般情况下我们只需要压缩包中的src文件夹中的文件,并保存至根目录即可:设置一个文件,如...

回顾使用PHP原生发送电子邮件(一)

IwishIcouldremembertheveryfirstemailmessageIeversent.Unfortunately,thetruthisthatI...

PHPMAILER实现PHP发邮件功能php实例

这篇文章主要为大家详细介绍了PHPMAILER实现PHP发邮件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下本文实例为大家分享了PHPMAILER实现PHP发邮件功能的具体代码,供大家参考,具...

500道网络安全面试题集锦(附答案)

本篇文章内容为网络安全各个方向涉及的面试题,星数越多代表问题出现的几率越大,但是无论如何都无法覆盖所有的面试问题,更多的还是希望由点达面,查漏补缺,然后祝各位前程似锦,都能找到自己满意的工作!一、We...

网站放家里,随处看电影「Apache+php+ssl 安装和配置」

  使用5G网络,随处都可以看到放自己家里电脑的视频。这个功能很容易实现,不需要太多的专业知识,也不需要额外花钱。如果确实需要,最多花不到两百块钱买一台旧电脑放家里,做个网站,就能解决全部问题,Fre...

Windows2008中 Magic Winmail Server提权

MagicWinmailServer是安全易用全功能的邮件服务器软件,不仅支持SMTP/POP3/IMAP/Webmail/LDAP(公共地址簿)/多域/发信认证/反垃圾邮件/邮件过滤/邮件组...

利用PHPmailer发送邮件

早上帮朋友做一个收集客户联系方式的页面,要求能实时推送信息给管理员。刚开始想到做后台管理,因为时间紧,做后台是赶不上了。想过通过短信发送,成本太高,否决了。。。灵机一动,客户提交时直接把信息发送到邮箱...

phpmailer发送邮件

phpmailer发送邮件PHP内置的mail函数使用起来不够方便,另外受其他语言的影响,博主更偏好面向对象的包管理模式,因此phpmailer成为了我用PHP发送邮件的首选,这里分享给大家。库导入这...

PHP初级教程:读取输入

PHP读取输入:Form:?formaction="welcome.php"method="post">Name:(inputtype="text...

php filter 验证Email,Url,Ip格式

今天发现一个非常好用的函数东西,filter过滤器,用于验证和过滤来自非安全来源的数据,比如用户的输入。验证Email:$email='1234567@qq.com';if(!filter_v...

取消回复欢迎 发表评论: