org.apache.poi.hssf之读取,写入单元格操作

1.写入

package test.testcase;

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

import org.apache.poi.hssf.usermodel.*;


/**
 * @Author: zhanglh
 * @Date: 2019/2/13 16:15
 * @Description:
 */
public class CreateWorkbook {

    public static void main(String args[]){
        HSSFWorkbook hssfworkbook=new HSSFWorkbook();
        File file=new File("test.xls");
        if(file.exists()){System.out.println("existing");}
        else
        {
            try
            {
                file.createNewFile();
            }
            catch(IOException e){
                e.printStackTrace();
            }
        }

        try
        {
            HSSFSheet sheet=hssfworkbook.createSheet("time");
            HSSFRow row=sheet.createRow(0);
            HSSFCell cell=row.createCell(0);
            cell.setCellValue(new Date());
            HSSFCell cell1=row.createCell(1);
            cell1.setCellValue("verify");
            FileOutputStream out=new FileOutputStream(file);
            hssfworkbook.write(out);
            out.close();
        }
        catch(IOException e1){
            e1.printStackTrace();
        }


        System.out.println("create xlsx successfully");


        System.out.println("create sheet successfully");
    }

}

 

2.读出

package test.testcase;

import java.io.*;
import org.apache.poi.hssf.usermodel.*;

/**
 * @Author: zhanglh
 * @Date: 2019/2/13 17:53
 * @Description:
 */
public class OpenWorkbook {
    public  static void main(String args[]) {
        File file = new File("test.xls");
        try {
            FileInputStream input = new FileInputStream(file);
            HSSFWorkbook workbook = new HSSFWorkbook(input);
            HSSFSheet sheet = workbook.getSheetAt(0);
            HSSFRow row = sheet.getRow(0);
            HSSFCell cell = row.getCell(0);
            /*switch (cell.getCellType()) {
                case Cell.CELL_TYPE_NUMERIC:*/
                    System.out.println("cell value:" + cell.getNumericCellValue());


                    //System.out.println("cell value:" + cell.getStringCellValue());


            }
        catch (IOException e) {
            e.printStackTrace();
        }

        if (file.exists()) {
            System.out.println("open");
        } else {
            System.out.println("failure");
        }

        System.out.println("read successfully");
    }
}

output:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这个错误的原因是你使用了POI库中处理OLE2 Office文档的部分,而你提供的数据是Office 2007+ XML格式的。因此,你需要使用POI库中处理XML文档的部分来处理这个数据。 具体来说,你需要使用XSSF而不是HSSF读取写入Office 2007+ XML格式的文件。下面是一个简单的读取Excel文件的例子: ```java //创建XSSFWorkbook对象 XSSFWorkbook workbook = new XSSFWorkbook(inputStream); //获取第一个工作表 XSSFSheet sheet = workbook.getSheetAt(0); //遍历行和单元格 for (Row row : sheet) { for (Cell cell : row) { //读取单元格的值 String cellValue = cell.getStringCellValue(); System.out.print(cellValue + "\t"); } System.out.println(); } ``` 如果你需要写入Office 2007+ XML格式的文件,你也需要使用XSSF来创建工作簿和工作表,并使用XSSFCell来创建单元格。下面是一个简单的写入Excel文件的例子: ```java //创建XSSFWorkbook对象 XSSFWorkbook workbook = new XSSFWorkbook(); //创建工作表 XSSFSheet sheet = workbook.createSheet("Sheet1"); //创建行和单元格写入数据 Row row = sheet.createRow(0); Cell cell = row.createCell(0); cell.setCellValue("Hello World"); //将工作簿写入文件 FileOutputStream outputStream = new FileOutputStream("output.xlsx"); workbook.write(outputStream); outputStream.close(); ``` 请注意,这两个例子中使用的是XSSF而不是HSSF。如果你使用的是HSSF,并且读取写入Office 2007+ XML格式的文件,那么就会出现上述错误。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值