如图,需要读取excel中的“9月份计划” 但是这里是合并的单元格,请问 怎么读取合格单元格的值,有什么好的思路么
public class POITest {
public static void main(String[] args) throws Exception {
File inputFile = new File("d:\\test.xlsx");
InputStream is = new FileInputStream(inputFile);
Workbook wb = new XSSFWorkbook(is);
Sheet sheet = wb.getSheetAt(0);
// 遍历合并区域
for (int i = 0; i < sheet.getNumMergedRegions(); i++) {
CellRangeAddress region = sheet.getMergedRegion(i); //
int colIndex = region.getFirstColumn(); // 合并区域首列位置
int rowNum = region.getFirstRow(); // 合并区域首行位置
System.out.println("第[" + i + "]个合并区域:" + sheet.getRow(rowNum).getCell(colIndex).getStringCellValue());
}
// 直接调用,我知道合并单元格的位置:
System.out.println(sheet.getRow(0).getCell(0).getStringCellValue());
System.out.println(sheet.getRow(3).getCell(2).getStringCellValue());
wb.close();
is.close();
}
}
输出:
全选复制放进笔记
第[0]个合并区域:foo
第[1]个合并区域:bar
foo
bar
用到的test.xlsx:
说白了,合并区域通过首列和首行来索引,如果你知道你的合并区域是sheet中的第几个,就不用遍历,直接调sheet.getMergedRegion()就行了。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。