HSSFWorkBook:操作2003版本以前的(包括2003版本),扩展名.xls,该类在org.apache.poi:poi中

XSSFWorkBook:操作2007版本以后的(包括2007版本),拓展名.xlsx,该类在org.apache.poi:poi-ooxml中

SXSSFWorkBook:对于海量的数据进行操作

对于不同版本的EXCEL文档要使用不同的工具类,如果使用错了,会提示如下错误信息。

org.apache.poi.openxml4j.exceptions.InvalidOperationException

org.apache.poi.poifs.filesystem.OfficeXmlFileException

HSSF对xls后缀名的Excel进行读取内容:

import org.apache.poi.hssf.usermodel.HSSFCell;
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.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.CellType;import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;/*** Created by M_WBCG on 2017/7/14.*/
public class ReadExcelForHSSF {public void read() {File file = new File("././POI/POI1.xls");if (!file.exists())System.out.println("文件不存在");try {//1.读取Excel的对象POIFSFileSystem poifsFileSystem = new POIFSFileSystem(new FileInputStream(file));//2.Excel工作薄对象HSSFWorkbook hssfWorkbook = new HSSFWorkbook(poifsFileSystem);//3.Excel工作表对象HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(0);//总行数int rowLength = hssfSheet.getLastRowNum()+1;//4.得到Excel工作表的行HSSFRow hssfRow = hssfSheet.getRow(0);//总列数int colLength = hssfRow.getLastCellNum();//得到Excel指定单元格中的内容HSSFCell hssfCell = hssfRow.getCell(0);//得到单元格样式CellStyle cellStyle = hssfCell.getCellStyle();for (int i = 0; i < rowLength; i++) {//获取Excel工作表的行HSSFRow hssfRow1 = hssfSheet.getRow(i);for (int j = 0; j < colLength; j++) {//获取指定单元格HSSFCell hssfCell1 = hssfRow1.getCell(j);//Excel数据Cell有不同的类型,当我们试图从一个数字类型的Cell读取出一个字符串时就有可能报异常://Cannot get a STRING value from a NUMERIC cell//将所有的需要读的Cell表格设置为String格式if (hssfCell1 != null) {hssfCell1.setCellType(CellType.STRING);}//获取每一列中的值System.out.print(hssfCell1.getStringCellValue() + "\t");}System.out.println();}} catch (IOException e) {e.printStackTrace();}}public static void main(String[] args) {new ReadExcelForHSSF().read();}
}

XSSF对xlsx后缀名的Excel进行读取内容:

import org.apache.poi.ss.usermodel.*;import java.io.*;/*** Created by M_WBCG on 2017/7/14.*/
public class ReadExcelForXSSF {public void read() {File file = new File("././POI/POI2.xlsx");InputStream inputStream = null;Workbook workbook = null;try {inputStream = new FileInputStream(file);workbook = WorkbookFactory.create(inputStream);inputStream.close();//工作表对象Sheet sheet = workbook.getSheetAt(0);//总行数int rowLength = sheet.getLastRowNum()+1;//工作表的列Row row = sheet.getRow(0);//总列数int colLength = row.getLastCellNum();//得到指定的单元格Cell cell = row.getCell(0);//得到单元格样式CellStyle cellStyle = cell.getCellStyle();System.out.println("行数:" + rowLength + ",列数:" + colLength);for (int i = 0; i < rowLength; i++) {row = sheet.getRow(i);for (int j = 0; j < colLength; j++) {cell = row.getCell(j);//Excel数据Cell有不同的类型,当我们试图从一个数字类型的Cell读取出一个字符串时就有可能报异常://Cannot get a STRING value from a NUMERIC cell//将所有的需要读的Cell表格设置为String格式if (cell != null)cell.setCellType(CellType.STRING);//对Excel进行修改if (i > 0 && j == 1)cell.setCellValue("1000");System.out.print(cell.getStringCellValue() + "\t");}System.out.println();}//将修改好的数据保存OutputStream out = new FileOutputStream(file);workbook.write(out);} catch (Exception e) {e.printStackTrace();}}public static void main(String[] args) {new ReadExcelForXSSF().read();}
}

在这里对Excel写入内容使用的XSSF(HSSF也是同样的道理,不再多举例 ):

import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.*;/*** Created by M_WBCG on 2017/7/14.*/
public class WriteExcelForXSSF {public void write() {Workbook workbook = new XSSFWorkbook();Sheet sheet = workbook.createSheet("0");Row row = sheet.createRow(0);CellStyle cellStyle = workbook.createCellStyle();// 设置这些样式cellStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);cellStyle.setBorderBottom(CellStyle.BORDER_THIN);cellStyle.setBorderLeft(CellStyle.BORDER_THIN);cellStyle.setBorderRight(CellStyle.BORDER_THIN);cellStyle.setBorderTop(CellStyle.BORDER_THIN);cellStyle.setAlignment(CellStyle.ALIGN_CENTER);row.createCell(0).setCellStyle(cellStyle);row.createCell(0).setCellValue("姓名");row.createCell(1).setCellStyle(cellStyle);row.createCell(1).setCellValue("年龄");workbook.setSheetName(0, "信息");try {File file = new File("././POI/POI3.xlsx");FileOutputStream fileoutputStream = new FileOutputStream(file);workbook.write(fileoutputStream);fileoutputStream.close();} catch (IOException e) {e.printStackTrace();}}public static void main(String[] args) {new WriteExcelForXSSF().write();}
}

java-使用POI对Excel进行读写操作相关推荐

  1. 使用Easyexcel对Excel进行读写操作

    1.概述 EasyExcel是一个基于Java的简单.省内存的读写Excel的开源项目.在尽可能节约内存的情况下支持读写百M的Excel. github地址:GitHub - alibaba/easy ...

  2. Java 使用 POI 对 Excel文件 进行读写操作

    Java 使用 POI 对 Excel文件 进行读写操作 一.背景 目前正在做一个问卷功能模块,收集完问卷信息后,需要将数据库中的数据导出到Excel数据表中进行留存,因此就学习了在Java中如何对E ...

  3. python对excel进行读写操作

    python对excel进行读写操作 欢迎使用Markdown编辑器 一.安装库 1.安装xlrd模块 2.安装xlwt模块 2.安装openpyxl模块 补充(多个python版本) 二.使用介绍 ...

  4. java使用poi生成Excel文件并合并单元格

    java使用poi生成Excel文件并合并单元格        业务需要根据 分管部门 字段进行合并,现在提供一种思路. controller层 @Inject(target = "/inf ...

  5. python写表格_使用Python对Excel进行读写操作

    学习Python的过程中,我们会遇到Excel的读写问题.这时,我们可以使用xlwt模块将数据写入Excel表格中,使用xlrd模块从Excel中读取数据.下面我们介绍如何实现使用Python对Exc ...

  6. excel调用python编程-使用Python对Excel进行读写操作

    学习Python的过程中,我们会遇到Excel的读写问题.这时,我们可以使用xlwt模块将数据写入Excel表格中,使用xlrd模块从Excel中读取数据.下面我们介绍如何实现使用Python对Exc ...

  7. Java结合POI清洗Excel

    Java结合POI清洗Excel 下文是Java结合POI清洗Excel的示例代码,详细内容如下: ShipEntry.java package com.liang.bi.excelmodel;pub ...

  8. java通过poi读取excel中的日期类型数据或自定义类型日期

    java通过poi读取excel中的日期类型数据或自定义类型日期 Java 读取Excel表格日期类型数据的时候,读出来的是这样的  12-十月-2019,而Excel中输入的是 2019/10/12 ...

  9. Java面试poi中excel版本大小_java 中 poi解析Excel文件版本问题解决办法

    java 中 poi解析Excel文件版本问题解决办法 发布时间:2020-10-02 03:46:15 来源:脚本之家 阅读:91 作者:程诺 poi解析Excel文件版本问题解决办法 poi解析E ...

最新文章

  1. 图像分割深度学习从零开始学习路线
  2. VS2010没有Intellisense(智能感知)的解决办法
  3. IntelliJ IDEA 转移C盘.IntelliJIdea(索引目录)
  4. php打开并填充表单,php – 创建一个’机器人’来填充带有一些页面的表单
  5. mysql-5.7.20实用下载、安装和配置方法,以及简单操作
  6. EndNote的PDF Handing功能, 让你的PDF管理井井有条
  7. asp按钮跳转页面代码_重磅更新!全新Web编辑页面、编辑规则快速跳转、状态栏变色、富文本再次升级!...
  8. [算法] vector删除元素
  9. Spring Boot 10:处理Json数据中的null值
  10. 【es】 check-rollover-ready read index [alinas-lcc] is not the wtiter index for alians [index-xx]
  11. laravel一键安装包
  12. 如何列出包含给定提交的分支?
  13. 监控视频异常检测数据集整理
  14. 透过微积分看芝诺悖论-龟兔赛跑
  15. 学计算机要做笔记吗,两个心理学实验告诉你,记笔记有多重要
  16. php生成盖章图片,印章图案生成器
  17. 桌面排版神器:Affinity Publisher for Mac
  18. 层次分析法算法及matlab和lingo求解一致性
  19. 编写站点robots文件
  20. 思科交换机接口安全配置

热门文章

  1. 在ARM-linux上实现4G模块simcom7100c 的PPP拨号上网
  2. python刷火车票_Python3实现火车票查询工具
  3. python下调用淘宝top接口例子
  4. 手机CPU知识扫盲:谈谈手机CPU架构与原理 (全
  5. dynamixel AX-12A
  6. JavaWeb开发工具
  7. 在PPT中插入FLASH遇到的系列问题
  8. 什么是超弦理论?它与姓名有什么关系?
  9. 【C语言小游戏】图书管理系统
  10. 时间与日期插件 -- laydate 使用方法(摘自官网)