POI Excel使用记录

PIO 关于Excel的一些使用

1
Iterator<Row> rit = sheet.rowIterator();

获取行迭代器对象
关于迭代器

迭代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构。迭代器通常被称为“轻量级”对象,因为创建它的代价小。

  Java中的Iterator功能比较简单,并且只能单向移动:

  (1) 使用方法iterator()要求容器返回一个Iterator。第一次调用Iterator的next()方法时,它返回序列的第一个元素。注意:iterator()方法是java.lang.Iterable接口,被Collection继承。

  (2) 使用next()获得序列中的下一个元素。

  (3) 使用hasNext()检查序列中是否还有元素。

  (4) 使用remove()将迭代器新返回的元素删除。

  Iterator是Java迭代器最简单的实现,为List设计的ListIterator具有更多的功能,它可以从两个方向遍历List,也可以从List中插入和删除元素。

1
Row rowHeader = rit.next();

获取一行的对象

1
2
3
4
row = rit.next();
int i = row.getPhysicalNumberOfCells();
int j = row.getLastCellNum();
int k = row.getRowNum;

i 获取当前行的列数(不包含空格,只计算有数据的部分)或者说当前行的长度
j 获取当前行的长度(包含空格)
k 获取当前行的行号

创建第0行:
Row rowA = sheet.createRow(0);
插入图片:

1
2
3
4
5
6
创建绘画对象
Drawing patriarch = sheet.createDrawingPatriarch();
创建锚对象
ClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) j, n, (short) (j + 1), n + 1);
在指定的锚位置插入图片
patriarch.createPicture(anchor, workbook.addPicture(cursor.getBlob(j), HSSFWorkbook.PICTURE_TYPE_JPEG));

写入文本:
cellA.setCellValue(new HSSFRichTextString(“” + columns.get(i)));