热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

POI编程

POI编程1简介在我们实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统中

POI编程

1 简介

在我们实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使用的浏览器,因为大家都用Windows。在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。

Apache的Jakata项目的POI子项目,目前比较成熟的是HSSF接口,处理MSExcel对象。它不象我们仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel对象,你可以控制一些属性如sheet,cell等等。

首先,理解一下一个Excel的文件的组织形式,一个Excel文件对应于一个workbook(HSSFWorkbook),一个workbook可以有多个sheet(HSSFSheet)组成,一个sheet是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。

POI可以到www.apache.org下载到。实际运行时,需要有poi包就可以了。HSSF提供给用户使用的对象在rg.apache.poi.hssf.usermodel包中,主要部分包括Excel对象,样式和格式,还有辅助操作。有以下几种对象:

  • HSSFWorkbook excel的文档对象
  • HSSFSheet excel的表单
  • HSSFRow excel的行
  • HSSFCell excel的格子单元
  • HSSFFont excel字体
  • HSSFDataFormat 日期格式
  • 在poi1.7中才有以下2项:
  • HSSFHeader sheet头
  • HSSFFooter sheet尾(只有打印的时候才能看到效果)
  • 和这个样式
  • HSSFCellStyle cell样式
  • 辅助操作包括
  • HSSFDateUtil 日期
  • HSSFPrintSetup 打印
  • HSSFErrorConstants 错误信息表

2 读取excel表格

2.1 导入jar包

需要的jar
    解析2003版excel. 
        poi-3.10-FINAL-20140208.jar
        commons-codec-1.5.jar
        commons-logging-1.1.jar
        log4j-1.2.13.jar
    解析2007版excel.
        dom4j-1.6.1.jar
        stax-api-1.0.1.jar
        xmlbeans-2.3.0.jar
        poi-ooxml-3.10-FINAL-20140208.jar
        poi-ooxml-schemas-3.10-FINAL-20140208.jar
POI编程
所有jar包.PNG

2.2 准备一个excel文件

这是我写好的excel文件

POI编程

2.3 编写解析excel文件的代码

package com.shenchen.poiutil;

import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * 解析Excel文件
 * 
 * @author Administrator
 *
 */
public class ParseExcel {
    
    /**
     * 解析文件的方法. 
     * @param inputStream 文件输入流, 要解析的Excel文件输入流
     * @param suffix 文件后缀名, xls或xlsx. 代码决定使用什么方式解析Excel.
     * @param startRow 从第几行开始读取数据.
     * @return List 集合中的一个元素对应一行解析的数据. 
     *      元素为字符串数组类型. 数组中的每个元素对应一列数据.
     * @throws IOException 
     */
    public List parseExcel(InputStream inputStream, String suffix, int startRow)
            throws IOException{
        
        // 1. 定义excel对象变量
        Workbook workbook = null;
        
        // 2. 判断后缀.决定使用的解析方式. 决定如何创建具体的对象
        if("xls".equals(suffix)){
            // 2003
            workbook = new HSSFWorkbook(inputStream);
        }else if("xlsx".equals(suffix)){
            // 2007
            workbook = new XSSFWorkbook(inputStream);
        }else{
            // 未知内容
            return null;
        }
        
        // 获取工作表  excel分为若干个表. sheet
        Sheet sheet = workbook.getSheetAt(0);
        
        if(sheet == null){
            return null;
        }
        
        // 获取表格中最后一行的行号
        int lastRowNum = sheet.getLastRowNum();
        
        // 最后一行的行号大于startRow
        if(lastRowNum  result = new ArrayList();
        
        // 定义行变量和单元格变量
        Row row = null;
        Cell cell = null;
        // 循环读取
        for(int rowNum = startRow; rowNum 

2.4 编写测试类测试

    @Test
    public void testParse() throws Exception{
        ParseExcel parser = new ParseExcel();
        InputStream inputStream = new FileInputStream("resource.xls");
        String suffix = "xls";
        int startRow = 3;
        
        List result = 
                parser.parseExcel(inputStream, suffix, startRow);
        
        for(String[] ss : result){
            System.out.println(Arrays.toString(ss));
        }
    }

2.5 运行检验测试成功

POI编程

3 写出excel表格

3.1 编写文件写出方法代码

package com.shenchen.poiutil;

import java.io.IOException;
import java.io.OutputStream;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;

/**
 * 导出Excel文件
 * 
 * @author Administrator
 *
 */
public class ExportExcel {
    
    /**
     * 文件导出方法. 
     * @param resource List 集合类型, 要导出的具体数据集合.
     * @param outputStream 输出流. 输出的excel文件保存的具体位置.
     * @throws IOException 
     */
    public void exportExcel(List resource, OutputStream outputStream) 
            throws IOException{
        
        // 创建一个内存Excel对象.
        HSSFWorkbook workbook = new HSSFWorkbook(); 
        
        // 创建一个表格.
        HSSFSheet sheet = workbook.createSheet("sheet1");
        
        // 创建表头
        // 获取表头内容.
        String[] headerStr = resource.get(0);
        HSSFRow headerRow = sheet.createRow(0);
        
        // 设置列宽
        for(int i = 0; i 

3.2 编写测试类测试

    @Test
    public void testExport() throws Exception{
        ExportExcel export = new ExportExcel();
        
        List resource = new ArrayList();
        resource.add(new String[]{"文本","地址","描述","是否是父菜单","父菜单ID"});
        resource.add(new String[]{"CRM系统管理", "null", "CRM系统顶级菜单", "T", "0"});
        resource.add(new String[]{"系统管理", "null", "系统管理", "T", "1"});
        resource.add(new String[]{"客户管理", "null", "客户管理", "T", "1"});
        resource.add(new String[]{"合同管理", "null", "合同管理", "T", "1"});
        resource.add(new String[]{"个人管理", "null", "个人管理", "T", "1"});
        resource.add(new String[]{"用户维护", "/user", "用户维护", "F", "2"});
        resource.add(new String[]{"用户查询", "/user", "用户查询", "F", "2"});
        resource.add(new String[]{"修改用户密码", "/user", "修改用户密码", "F", "2"});
        resource.add(new String[]{"客户维护", "/cus", "客户维护", "F", "3"});
        resource.add(new String[]{"客户查询", "/cus", "客户查询", "F", "3"});
        resource.add(new String[]{"合同维护", "/contract", "合同维护", "F", "4"});
        resource.add(new String[]{"合同查询", "/contract", "合同查询", "F", "4"});
        resource.add(new String[]{"查询个人信息", "/self", "查询个人信息", "F", "5"});
        resource.add(new String[]{"修改个人信息", "/self", "修改个人信息", "F", "5"});
        resource.add(new String[]{"修改个人密码", "/self", "修改个人密码", "F", "5"});
        
        OutputStream outputStream = new FileOutputStream("exportFile.xls");
        
        export.exportExcel(resource, outputStream);
        
        outputStream.flush();
        outputStream.close();
    }

3.3 测试成功

POI编程

推荐阅读
  • Python处理Word文档的高效技巧
    本文详细介绍了如何使用Python处理Word文档,涵盖从基础操作到高级功能的各种技巧。我们将探讨如何生成文档、定义样式、提取表格数据以及处理超链接和图片等内容。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 本文介绍如何使用 Python 获取文件和图片的创建、修改及拍摄日期。通过多种方法,如 PIL 库的 _getexif() 函数和 os 模块的 getmtime() 和 stat() 方法,详细讲解了这些技术的应用场景和注意事项。 ... [详细]
  • 深入理解Redis的数据结构与对象系统
    本文详细探讨了Redis中的数据结构和对象系统的实现,包括字符串、列表、集合、哈希表和有序集合等五种核心对象类型,以及它们所使用的底层数据结构。通过分析源码和相关文献,帮助读者更好地理解Redis的设计原理。 ... [详细]
  • 本文介绍如何使用 Python 的 xlrd 库读取 Excel 文件,并将其数据处理后存储到数据库中。通过实际案例,详细讲解了文件路径、合并单元格处理等常见问题。 ... [详细]
  • Python 异步编程:ASGI 服务器与框架详解
    自 Python 3.5 引入 async/await 语法以来,异步编程迅速崛起,吸引了大量开发者的关注。本文将深入探讨 ASGI(异步服务器网关接口)及其在现代 Python Web 开发中的应用,介绍主流的 ASGI 服务器和框架。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 本文介绍了MindManager在项目管理中的强大功能,特别是其内置的甘特图工具。通过该工具,用户可以轻松创建和管理项目计划,优化任务分配,并与其他软件无缝集成。 ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 本文详细介绍了如何在Kendo UI for jQuery的数据管理组件中,将行标题字段呈现为锚点(即可点击链接),帮助开发人员更高效地实现这一功能。通过具体的代码示例和解释,即使是新手也能轻松掌握。 ... [详细]
  • 本文介绍了解决在Windows操作系统或SQL Server Management Studio (SSMS) 中遇到的“microsoft.ACE.oledb.12.0”提供程序未注册问题的方法,特别针对Access Database Engine组件的安装。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • PHP数组平均值计算方法详解
    本文详细介绍了如何在PHP中计算数组的平均值,涵盖基本概念、具体实现步骤及示例代码。通过本篇文章,您将掌握使用PHP函数array_sum()和count()来求解数组元素的平均值。 ... [详细]
  • 深入解析Nginx中的Location指令及其属性
    本文将详细探讨Nginx配置文件中关键的location指令,包括其三种匹配方式(精准匹配、普通匹配和正则匹配),以及如何在实际应用中灵活运用这些匹配规则。此外,还将介绍location下的重要子元素如root、alias和proxy_pass,并解释相关参数的使用方法。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
author-avatar
哀公家园_678
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有