npoi 删除行
npoi 删除行
2016年07月19日 17:28:27 wsqplsh 阅读数:4246
删除行
一般情况下,删除行时会面临两种情况:删除行内容但保留行位置、整行删除(删除后下方单元格上移)。对应的删除方法分别是:removeRow()及shiftRow(startRow,endRow,shiftCount)
示例代码:
以下代码是使用removeRow()方法删除行内容但保留行位置。代码从d:\test.xls中的第一个sheet中删除了第一行。需要注意的是,改变是需要在workbook.write之后才生效的。
importorg.apache.poi.hssf.usermodel.*;
importjava.io.*;
public classtestTools{
public static voidmain(String[] args){
try{
FileInputStream is = newFileInputStream("d://test.xls");
HSSFWorkbook workbook = newHSSFWorkbook(is);
HSSFSheet sheet = workbook.getSheetAt(0);
HSSFRow row = sheet.getRow(0);
sheet.removeRow(row);
FileOutputStream os = newFileOutputStream("d://test.xls");
workbook.write(os);
is.close();
os.close();
} catch(Exception e) {
e.printStackTrace();
}
}
}
以下代码是使用shiftRow实现删除整行的效果。同样,也是需要在进行workbook.write后才会生效。
importorg.apache.poi.hssf.usermodel.*;
importjava.io.*;
public classtestTools{
public static voidmain(String[] args){
try{
FileInputStream is = newFileInputStream("d://test.xls");
HSSFWorkbook workbook = newHSSFWorkbook(is);
HSSFSheet sheet = workbook.getSheetAt(0);
sheet.shiftRows(1, 4, -1);
FileOutputStream os = newFileOutputStream("d://test.xls");
workbook.write(os);
is.close();
os.close();
} catch(Exception e) {
e.printStackTrace();
}
}
}
其中:
sheet.shiftRows(startRow,endRow,shiftCount)参数说明:
其含义是指从startRow EndRow往上移动或者是往下移动,当shiftcount为-1时表示的是上移,当为正时表示的是下移,通过移动来彻底删除。
(经过vb.net 2008 + NPOI 1.3的测试,负数只能是-1,如果需要往上移动多行,那么只有循环了)
相关文章
- tp5 model 中的软删除
- MYSQL删除重复记录
- eggjs 实现 删除 服务端上传的图片
- vue2.0 自定义 侧滑删除(LeftSlider)组件
- 基于redis的keys、scan删除ttl为-1的key
- C/C++注册表【2】打开,创建,删除
- 如何用vue封装一个防用户删除的平铺页面的水印组件
- Swift3.0语言教程删除字符与处理字符编码
- mysql创建索引,mysql索引优化,mysql索引创建删除
- php 删除二维数组中某个key值
- glusterFS 删除节点 容量均衡gluster volume rebalance
- 在近排博客活动已被删除几篇文章
- 快速删除一个“大目录”
- 【C#】删除集合(Collection)里的元素(Item)
- Twitter迅速删除庆祝尼斯恐袭的推特