首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Java Web开发 >

POI操作EXCEL的有关问题,添加批注,设置背景色不成功,

2013-01-23 
POI操作EXCEL的问题,添加批注,设置背景色不成功,请指教。读取一个现有的excel文件,对每行数据验证,在出错的

POI操作EXCEL的问题,添加批注,设置背景色不成功,请指教。
读取一个现有的excel文件,对每行数据验证,在出错的地方加上批注,设置背景色,然后保存成另外一个文件,代码如下:
String fileName = "resource.xls";

POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream(
"D:\\upload\"
+ fileName));
HSSFWorkbook resourceFile = new HSSFWorkbook(fs);
// TODO 验证处理

// 单位工作表
HSSFSheet shOrg = resourceFile.getSheet("Sheet1");
if (shOrg == null) {
return;
}
int lastRowNum = shOrg.getLastRowNum();// 取得最后一行
HSSFRow curRow = null;
HSSFCell curCell = null;
HSSFComment comment = null;
HSSFCellStyle cellStyle = null;
// 创建HSSFPatriarch对象,HSSFPatriarch是所有注释的容器.
HSSFPatriarch patr = shOrg.createDrawingPatriarch();
for (int rowNum = 1; rowNum <= lastRowNum; rowNum++) {
curRow = shOrg.getRow(rowNum);
// 单位名称
curCell = curRow.getCell(0);
// 添加单元格注释
// 定义注释的大小和位置,详见文档
HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,
(short) 3, 3, (short) 5, 6);

comment = patr.createCellComment(anchor);
// 设置注释内容
comment.setString(new HSSFRichTextString(" 单位名称不正确! "));
comment.setAuthor("test");
curCell.setCellComment(comment);

// 设置单元格背景
cellStyle = resourceFile.createCellStyle();
cellStyle.setFillBackgroundColor(HSSFColor.DARK_RED.index);
curCell.setCellStyle(cellStyle);

}

// 保存文件
String outputFileName = "error_resource.xls";
FileOutputStream stream = new FileOutputStream(new File(
"D:\\upload\"
+ outputFileName));
resourceFile.write(stream);
stream.close();
[解决办法]


public static void main(String[] args) throws IOException { 
  //创建工作簿对象 
  HSSFWorkbook wb=new HSSFWorkbook(); 
  //创建工作表对象 
  HSSFSheet sheet=wb.createSheet("我的工作表"); 
  //创建绘图对象 
  HSSFPatriarch p=sheet.createDrawingPatriarch(); 
  //创建单元格对象,批注插入到4行,1列,B5单元格 
  HSSFCell cell=sheet.createRow(4).createCell(1); 
  //插入单元格内容 
  cell.setCellValue(new HSSFRichTextString("批注")); 
  //获取批注对象 
  //(int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2) 
  //前四个参数是坐标点,后四个参数是编辑和显示批注时的大小. 
  HSSFComment comment=p.createComment(new HSSFClientAnchor(0,0,0,0,(short)3,3,(short)5,6)); 
  //输入批注信息 
  comment.setString(new HSSFRichTextString("插件批注成功!插件批注成功!")); 
  //添加作者,选中B5单元格,看状态栏 
  comment.setAuthor("toad"); 
  //将批注添加到单元格对象中 
  cell.setCellComment(comment); 
  //创建输出流 
  FileOutputStream out=new FileOutputStream("writerPostil.xls"); 
   
  wb.write(out); 
  //关闭流对象 
  out.close(); 



[解决办法]
OK,参照4楼的内容,LZ的程序需要修改的地方是:

// 设置单元格背景
cellStyle = resourceFile.createCellStyle();
cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
cellStyle.setFillForegroundColor(HSSFColor.DARK_RED.index);
curCell.setCellStyle(cellStyle);

这Excel前景色和后景色还真是有点别扭。

还有一点需要注意的是程序自己读出来的行数有可能超,这样可能会在某些行上报NPE错。

热点排行