POI 读取Excel表格 遇到的坑

最近需要读取表格中的数据拼接成inset语句写惹到文件中。跑了一下百度上大佬的代码,第一次美滋滋成功了,但是遇到不同的单元格会出现不同的坑。特地记录一下。
1.XSSF试用于office 2007以后的Excel表格;HSSF适合用于07版本之前的

2.getRawValue() 这个方法获取的值,不一样,尽量少用
getStringCellValue() 将单元格的值转换成字符串
getNumbericCellValue() 将单元格的值转换成数字(double类型)

3.有时候会出现在一列中出现的值 ,既有数字也有文本。可以使用toString()方法,转换

4.有时候单元格中的值会出现用trim()方法也无法去掉两端的空格。这种情况可能是值两端的空格是全角空格。可以直接在Excel中替换,也可以使用replaceAll方法替换

5.读取拼音转换成insert语句中的值时,拼音中的单引号需要转义
在这个情况下,使用replaceAll("’","\’")是无效的,因为replaceAll是不支持转义字符的,要使用replace方法。

6.表格一定要把数据后面没用的单元格删掉,否则读取的时候会出现空指针

暂时就想到这些了,之后再补充

示例代码

public static void readTable() throws Exception {
       //读取的文件
        InputStream ips = new FileInputStream("D://");
        //写入文件
        File file = new File("D://");
        if (!file.exists()) {
            file.createNewFile();
        }
        FileWriter fw = new FileWriter(file, false);
        BufferedWriter bw = new BufferedWriter(fw);
        //将获取的文件转换为工作簿
        XSSFWorkbook wb = new XSSFWorkbook(ips);
        //获取工作簿中的第一个sheet
        XSSFSheet sheet = wb.getSheetAt(0);       
        //按行读取
        for (Iterator ite = sheet.rowIterator(); ite.hasNext(); ) {
            XSSFRow row = (XSSFRow) ite.next();
            //首行不读取(未验证)
            if (row.getRowNum() == 0) {
                               continue;        }
            //获取第一行的第一列
            String mapping = row.getCell(0).getRawValue();
             //获取第一行的第二列
            String name = row.getCell(1).getStringCellValue();
            if (it.hasNext() == false) {
                    System.out.println(jinjingName);         }            
                if (ss && qwe0000) {
                    String str = "";
                    bw.write(str);
                    break;
                }
            }
        bw.close();
        fw.close();
    }

你可能感兴趣的:(小白的bug)