• String real_path = request.getSession().getServletContext().getRealPath("/");//获取文件路径,我是通过模板进行导出,在项目中拿到模板
  • if (!real_path.endsWith("/")) {
  •   real_path = real_path + "/";
  • }
  • String r_url = real_path + "excel/bixuan.xls";//拼接好文件的完整路径
  • String excelPath = r_url;
  • String sheetName = "Sheet1";//获取到不同的sheet页。
  • String sheetName1 = "Sheet2";

//拿到文件路径后创建excel对象

  • File f = new File(excelPath );
  • FileInputStream fis =fis = new FileInputStream(f);
  • HSSFWorkbook wb =wb = new HSSFWorkbook(fis);
  • HSSFWorkbook wb = util.createWorkBook(excelPath);
  • HSSFSheet sheet = wb.getSheet(sheetName)
  • HSSFSheet sheet1 = wb.getSheet(sheetName1)

//设置样式

  • HSSFCellStyle style = wb.createCellStyle();
  • style.setWrapText(true);
  • style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  • style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);

//设置边框

  • style.setBorderBottom(HSSFCellStyle.BORDER_THIN); //下边框
  • style.setBorderLeft(HSSFCellStyle.BORDER_THIN);//左边框
  • style.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框
  • style.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框

//设置字体

  • HSSFFont font2 = wb.createFont();
  • font2.setFontName("仿宋_GB2312");
  • font2.setFontHeightInPoints((short) 9);//字体大小
  • style.setFont(font2);
  • sheet.protectSheet("123456");//设置密码,保护单元格
  • sheet1.protectSheet("123456");
  • style.setWrapText(true);//一定要有这个,否则设置单元格密码失效

//在excel中插入的行

  • sheet.shiftRows(len-1, len+20, find.size()-5, true, false);//参数详解  1从这行行开始移动,2到那行结束 3移动的数量

//合并单元格后,边框样式对合并的单元格不起作用,需要用下面代码处理

  • CellRangeAddress cellRangeAddress = new CellRangeAddress(len-1,len-1,3,5);//参数,合并单元格的开始行数,与结束行数。
  • int addMergedRegion = sheet.addMergedRegion(cellRangeAddress);//合并单元格
  • sheet.getRow(len-1).getCell(2).setCellStyle(style);设置样式

//不同浏览器对导出的excel有不同的编码,做如下处理

  • if(isMSBrowser(request)){
  • xlsName = java.net.URLEncoder.encode(xlsName, "utf-8") + ".xls";
  • } else {
  • xlsName = new String(xlsName.getBytes("utf-8"), "iso-8859-1") + ".xls";
  • }

//判断是不是ie浏览器

  • public boolean isMSBrowser(HttpServletRequest request) {
  • String[] IEBrowserSignals = {"MSIE", "Trident", "Edge"};
  • String userAgent = request.getHeader("User-Agent");
  • for (String signal : IEBrowserSignals) {
  • if (userAgent.contains(signal)){
  • return true;
  • }
  • }
  • return false;
  • }

//封装一下对合并单元格的边框处理

  • public void setBorderStyle(int border, CellRangeAddress region, HSSFSheet sheet, HSSFWorkbook wb){
  • RegionUtil.setBorderBottom(border, region, sheet, wb);//下边框
  • RegionUtil.setBorderLeft(border, region, sheet, wb);//左边框
  • RegionUtil.setBorderRight(border, region, sheet, wb); //右边框
  • RegionUtil.setBorderTop(border, region, sheet, wb); //上边框
  • }

借鉴博客:https://www.cnblogs.com/staticxy/p/6122336.html

    https://www.cnblogs.com/dcncy/p/8041657.html

excel使用poi操作。的更多相关文章

  1. 从数据库导出数据到excel之POI操作

    项目说明: 1:数据库中有两张表,主键关联 2:根据条件查询数据 3:处理为需要的数据封装类型,然后传到导出excel的方法中 <--框架部署就不详谈了,用的spring框架--> 补充: ...

  2. POI操作Excel

    POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...

  3. JAVA的POI操作Excel

    1.1Excel简介 一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作表sheet,而一个工作表中包含多个单元格Cell,这些单元格都是由列(Column)行(Row)组 ...

  4. poi操作excel的基本用法

    这周公司要用excel作为数据存储格式做一个文具申请的功能,感觉以前本来很简单的功能变复杂了不少,但是还是记录一下一些excel的基本用法. 写在最前面:这里只介绍一些excel的基本存储方式(读,写 ...

  5. 自己封装的poi操作Excel工具类

    自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...

  6. poi 操作excel

    poi操作 创建一个excel关联对象HSSFWorkbook: HSSFWorkbook book = new HSSFWorkbook(); 创建一个sheet: HSSFSheet st = b ...

  7. 自己的包poi操作Excel工具

    在前面的文章<使用poi读写Excel>中分享了一下poi操作Excel的简单演示样例.这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完毕的功能是:读取Excel.汇总E ...

  8. 一脸懵逼学习Java操作Excel之POI(Apache POI)

    Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 1:下面简单的程序来创建一个空白Microsoft ...

  9. Java POI操作Excel注意点

    excel的行索引和列索引都是从0开始,而行号和列号都是从1开始 POI·操作excel基本上都是使用索引 XSSFRow对象的 row.getLastCellNum() 方法返回的是当前行最后有效列 ...

随机推荐

  1. SVN和Git的功能和区别,尚学堂SVN和Git学习视频资料免费下载

    对于软件开发人员来说,版本控制系统再熟悉不过了,所谓版本控制系统就是软件项目开发过程中用于储存开发人员所写代码所有修订版本的软件.目前常见的版本控制系统分为集中式版本控制系统(SVN)和分布式版本控制 ...

  2. [Swift]LeetCode77. 组合 | Combinations

    Given two integers n and k, return all possible combinations of k numbers out of 1 ... n. Example: I ...

  3. zuul进阶学习(二)

    1. zuul进阶学习(二) 1.1. zuul对接apollo 1.1.1. Netflix Archaius 1.1.2. 定期拉 1.2. zuul生产管理实践 1.2.1. zuul网关参考部 ...

  4. java中this和super关键字的使用

    这几天看到类在继承时会用到this和super,这里就做了一点总结,与各位共同交流,有错误请各位指正~ this this是自身的一个对象,代表对象本身,可以理解为:指向对象本身的一个指针. this ...

  5. Storm学习笔记 - Storm初识

    Storm学习笔记 - Storm初识 1. Strom是什么? Storm是一个开源免费的分布式计算框架,可以实时处理大量的数据流. 2. Storm的特点 高性能,低延迟. 分布式:可解决数据量大 ...

  6. Vue轻松入门,一起学起来!

    我们创建一个项目,这个项目我们细说Vue. 一.如何在项目中添加模块 我们通过npm 进行 安装 模块. 首先我们通过cmd.exe cd进入你的项目根目录,必须存在package.json文件,安装 ...

  7. Qt之QComboBox定制(二)

    上一篇文章Qt之QComboBox定制讲到了qt实现自定义的下拉框,该篇文章主要实现了列表式的下拉框,这一节我还将继续讲解QComboBox的定制,而这一节我将会讲述更高级的用法,不仅仅是下拉列表框, ...

  8. 『字符串模式匹配 KMP』

    字符串模式匹配 我们要先了解一下问题是什么. 模式匹配是数据结构中字符串的一种基本运算,给定一个子串,要求在某个字符串中找出与该子串相同的所有子串,这就是模式匹配. KMP 然后我们来认识一下今天的主 ...

  9. Kafka从入门到进阶

    1.  Apache Kafka是一个分布式流平台 1.1  流平台有三个关键功能: 发布和订阅流记录,类似于一个消息队列或企业消息系统 以一种容错的持久方式存储记录流 在流记录生成的时候就处理它们 ...

  10. C#版(击败100.00%的提交) - Leetcode 151. 翻转字符串里的单词 - 题解

    版权声明: 本文为博主Bravo Yeung(知乎UserName同名)的原创文章,欲转载请先私信获博主允许,转载时请附上网址 http://blog.csdn.net/lzuacm. C#版 - L ...