栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java使用POI框架的简单操作(读取、编辑、导出)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java使用POI框架的简单操作(读取、编辑、导出)

Java使用POI框架对Excel简单操作 导入依赖

	org.apache.poi
	poi
	4.0.1

读取Excel文件 加载Excel文件

因为Excel2003(及以前的版本)和Excel2007(及以后的版本)数据保存形式的不同,因此不同版本Excel文件使用POI读取的方式也有所不同。可以根据Excel文件的后缀名判断Excel文件的版本。

.xls的为2003,.xlsx的为2007

public class importExcelFile{
    public static void main(String args[]){
        //创建文件对象
        File excel = new File("这里填写excel文件的路径");
        //创建文件输入流
        FileInputStream fis = new FileInputStream(excel);
        //获取excel文件的后缀,注意.需要转义
        String[] split = excel.getName().split("\.");
        //根据后缀判断文件版本,来获取workbook(用于操作excel文件的对象)
         if ("xls".equals(split[1])) {
                try {
                    workbook = new HSSFWorkbook(fis);
                } catch (Exception e) {
                    try {
                        workbook = new XSSFWorkbook(excel);
                    } catch (Exception ex) {
                        workbook = null;
                    }
                }
            } else if ("xlsx".equals(split[1])) {
                try {
                    workbook = new XSSFWorkbook(excel);
                } catch (Exception e) {
                    try {
                        workbook = new HSSFWorkbook(fis);
                    } catch (Exception ex) {
                        workbook = null;
                    }
                }
            }
    }
}
获取Excel内容

这里以Excel2007版本的XSSFWorkbook举例,读取第1个单元格的值

public void readExcel(XSSFWorkbook workbook){
    //1.获取要读取的sheet对象,这里是以索引获取第0个sheet
    Sheet sheet = workbook.getsheet(0);
    //2.获取sheet中的行对象Row,这里获取了第0行
    HSSFRow row = sheet.getRow(0);
    //3.获取第0行中第一个单元格对象Cell
    HSSFCell cell = row.getCell(0);
    //4.输出单元格cell的值
    System.out.println(cell.toString());
}

poi读取Excel只能以一行一行的形式来读,我们遍历Excel的时候还会常用到以下几个方法。

//对sheet操作
sheet.getFirstRowNum();//获取表中第一行数据的行号
sheet.getLastRowNum();//获取表中最后一行数据的行号
//对row操作
row.getFirstCellNum();//获取行中第一个含有数据的单元格的列号
row.getLastCellNum();//获取行中第一个含有数据的单元格的列号
编辑、保存导出Excel文件 编辑Excel内容

编辑第0个单元格的值为“abc”

public void editExcel(XSSFWorkbook workbook){
    //1.获取要读取的sheet对象,这里是以索引获取第0个sheet
    Sheet sheet = workbook.getsheet(0);
    //2.获取sheet中的行对象Row,这里获取了第0行
    HSSFRow row = sheet.getRow(0);
    //3.获取第0行中第一个单元格对象Cell
    HSSFCell cell = row.getCell(0);
    //4.修改单元格的值
    cell.setCellValue("abc");
}
保存Excel文件

保存导出Excel文件到指定路径

public void output(XSSFWorkbook workbook){
    try{
        //1.创建outputsteam对象用于导出
		OutputStream out = new outputstream(new File("要保存的路径"));
        //2.调用XSSFWorkbook的write方法导出
        workbook.write(out);
        //3.关闭资源
        workbook.close();
        out.close();
    }catch(Exception e){
        e.printStackTrace();
    }    
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/340783.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号