最近需要读取表格中的数据拼接成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();
}