java使用POI3.15读写excel

import java.io.*;
import java.util.*;

import org.apache.commons.io.FileUtils;
import org.apache.poi.ss.usermodel.*;

import javax.annotation.Resource;
public class ExcelImport {
    public void eximport() throws IOException {
        String fileName = "D:/Project/读入文档.xlsx";
        File targetFile = new File(fileName);
        if(!targetFile.exists()){
            //log.info("指定文件不存在");
        }

       //读入excel文件
        InputStream ips = new FileInputStream(targetFile);
        Workbook workbook=null;
        List<List<Object>> list = new LinkedList<>();
        try{
            workbook=  WorkbookFactory.create(ips);
            Sheet sheet = workbook.getSheetAt(0);//ecxel获取的第一个表单sheet
            for(Row row:sheet){//从第一行开始
                List<Object> linked = new LinkedList<>();
                for(Cell cell:row){//excel从每个单元格遍历的
                    linked.add(new DataFormatter().formatCellValue(cell));
                }
                list.add(linked);
            }

           //此时文件输入流里面有list对象[[xx,xx,xx],[xx,xx,xx],[xx,xx,xx],[xx,xx,xx] ]
            String fileName2 = "D:/Project/新文档.xlsx";//要存的地址
            File targetFile2 = new File(fileName2);
            targetFile2.createNewFile();//新建一个文件
            Sheet sheet1 = workbook.createSheet("data");
            Row firstRow = sheet.createRow(0);
            int i = 0;
            for (List data : list) {
                Row row = sheet.createRow(i);//建立第一行
                for (int j = 0; j <list.get(0).size(); j++) {//从列开始读
                    Object obj = data.get(j);
                    row.createCell(j).setCellValue(obj != null ? obj.toString() : "");//写入值可以自己设置

                 //for循环是为了方便直接读输入流内容,可以按需要设置写入值
                }
                i++;
            }
           FileOutputStream stream= FileUtils.openOutputStream(targetFile2);

          //此时文件输出流里面有list对象[[xx,xx,xx],[xx,xx,xx],[xx,xx,xx],[xx,xx,xx] ]
           workbook.write(stream);
            stream.close();
        }catch (Exception e){
            //log.info("打开EXCEL文件流失败!e:{}", e);
        }
        return;

    }
    public static void main(String[] args) throws IOException {
        ExcelImport ff = new ExcelImport();
        ff.eximport();
    }
}

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java使用POI库可以实现对Excel文件的读取操作。具体的步骤如下: 1. 引用POI库。在Java项目中引入POI相关的jar包。 2. 创建文件输入流。使用FileInputStream类创建一个输入流对象,并指定要读取的Excel文件路径。 3. 创建工作簿对象。使用HSSFWorkbook类创建一个工作簿对象,将输入流作为参数传入。 4. 获取工作表。使用getSheetAt方法获取指定的工作表,可以通过工作表的索引或名称进行获取。 5. 获取行。使用getRow方法获取指定行的对象,行号作为参数传递给该方法。 6. 获取单元格。使用getCell方法获取指定单元格的对象,行号和列号作为参数传递给该方法。 7. 获取单元格的值。使用getStringCellValue方法获取单元格的值,将其赋给一个字符串变量。 8. 输出结果。使用System.out.println方法将获取到的数据打印出来。 需要注意的是,在读取Excel文件时可能会出现FileNotFoundException和IOException异常,需要进行异常处理。同时,在读取完成后,需要关闭输入流。 下面是一个示例代码,用于演示Java使用POI读取Excel文件: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; 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; public class ExcelReader { public static void poiRead() { FileInputStream xlsStream = null; try { // 创建文件输入流 xlsStream = new FileInputStream(new File("C:\\Users\\itour\\Desktop\\poiTest.xls")); // 创建工作簿对象 HSSFWorkbook hssfWorkbook = new HSSFWorkbook(xlsStream); // 获取工作表 HSSFSheet sheetAt = hssfWorkbook.getSheetAt(0); // 获取行 HSSFRow row = sheetAt.getRow(0); // 获取单元格 HSSFCell cell = row.getCell(0); // 获取单元格的值 String cellValue = cell.getStringCellValue(); System.out.println("获取到的数据是:" + cellValue); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (xlsStream != null) { try { xlsStream.close(); } catch (IOException e) { e.printStackTrace(); } } } } } ``` 以上代码演示了如何使用POI库读取Excel文件中第一个工作表的第一个单元格的值。你可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值