日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

(6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug...

發布時間:2025/3/8 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 (6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

如果POI-3.10往一個工作表(sheet)里面插入數據的話,需要注意了,其有一個不太被容易發現的bug。 被插入的工作表(sheet)里面的單元格沒有包含任何的注解(comment)的時候,插入一行數據,不會有任何問題。但是如果被插入的工作表(sheet)里面的單元格只要包含任何的注解(comment)的時候,這個時候插入一行數據的時候,就會破壞這個文件。當程序執行完后,如果打開被插入數據的Excel文件,我們將會發現,其會彈出下面的對話框。

程序代碼如下,

?

[java]?view plaincopy
  • package?com.tibco.poi.xssf;??
  • ??
  • import?java.io.File;??
  • import?java.io.FileInputStream;??
  • import?java.io.FileNotFoundException;??
  • import?java.io.FileOutputStream;??
  • import?java.io.IOException;??
  • ??
  • import?org.apache.poi.xssf.usermodel.XSSFCell;??
  • import?org.apache.poi.xssf.usermodel.XSSFRow;??
  • import?org.apache.poi.xssf.usermodel.XSSFSheet;??
  • import?org.apache.poi.xssf.usermodel.XSSFWorkbook;??
  • ??
  • public?class?CreatRowTest?{??
  • ????//當前文件已經存在??
  • ????private?String?excelPath?=?"D:\\exceltest\\comments.xlsx";??
  • ????//從第幾行插入進去??
  • ????private?int?insertStartPointer?=?3;??
  • ????//在當前工作薄的那個工作表單中插入這行數據???
  • ????private?String?sheetName?=?"Sheet1";??
  • ??
  • ????/**?
  • ?????*?總的入口方法?
  • ?????*/??
  • ????public?static?void?main(String[]?args)?{??
  • ????????CreatRowTest?crt?=?new?CreatRowTest();??
  • ????????crt.insertRows();??
  • ????}??
  • ????/**?
  • ?????*?在已有的Excel文件中插入一行新的數據的入口方法?
  • ?????*/??
  • ????public?void?insertRows()?{??
  • ????????XSSFWorkbook?wb?=?returnWorkBookGivenFileHandle();??
  • ????????XSSFSheet?sheet1?=?wb.getSheet(sheetName);??
  • ????????XSSFRow?row?=?createRow(sheet1,?insertStartPointer);??
  • ????????createCell(row);??
  • ????????saveExcel(wb);??
  • ??
  • ????}??
  • ????/**?
  • ?????*?保存工作薄?
  • ?????*?@param?wb?
  • ?????*/??
  • ????private?void?saveExcel(XSSFWorkbook?wb)?{??
  • ????????FileOutputStream?fileOut;??
  • ????????try?{??
  • ????????????fileOut?=?new?FileOutputStream(excelPath);??
  • ????????????wb.write(fileOut);??
  • ????????????fileOut.close();??
  • ????????}?catch?(FileNotFoundException?e)?{??
  • ????????????e.printStackTrace();??
  • ????????}?catch?(IOException?e)?{??
  • ????????????e.printStackTrace();??
  • ????????}??
  • ??
  • ????}??
  • ????/**?
  • ?????*?創建要出入的行中單元格?
  • ?????*?@param?row?
  • ?????*?@return?
  • ?????*/??
  • ????private?XSSFCell?createCell(XSSFRow?row)?{??
  • ????????XSSFCell?cell?=?row.createCell((short)?0);??
  • ????????cell.setCellValue(999999);??
  • ????????row.createCell(1).setCellValue(1.2);??
  • ????????row.createCell(2).setCellValue("This?is?a?string?cell");??
  • ????????return?cell;??
  • ????}??
  • ???/**?
  • ????*?得到一個已有的工作薄的POI對象?
  • ????*?@return?
  • ????*/??
  • ????private?XSSFWorkbook?returnWorkBookGivenFileHandle()?{??
  • ????????XSSFWorkbook?wb?=?null;??
  • ????????FileInputStream?fis?=?null;??
  • ????????File?f?=?new?File(excelPath);??
  • ????????try?{??
  • ????????????if?(f?!=?null)?{??
  • ????????????????fis?=?new?FileInputStream(f);??
  • ????????????????wb?=?new?XSSFWorkbook(fis);??
  • ????????????}??
  • ????????}?catch?(Exception?e)?{??
  • ????????????return?null;??
  • ????????}?finally?{??
  • ????????????if?(fis?!=?null)?{??
  • ????????????????try?{??
  • ????????????????????fis.close();??
  • ????????????????}?catch?(IOException?e)?{??
  • ????????????????????e.printStackTrace();??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ????????return?wb;??
  • ????}??
  • ???/**?
  • ????*?找到需要插入的行數,并新建一個POI的row對象?
  • ????*?@param?sheet?
  • ????*?@param?rowIndex?
  • ????*?@return?
  • ????*/??
  • ????private?XSSFRow?createRow(XSSFSheet?sheet,?Integer?rowIndex)?{??
  • ????????XSSFRow?row?=?null;??
  • ????????if?(sheet.getRow(rowIndex)?!=?null)?{??
  • ????????????int?lastRowNo?=?sheet.getLastRowNum();??
  • ????????????sheet.shiftRows(rowIndex,?lastRowNo,?1);??
  • ????????}??
  • ????????row?=?sheet.createRow(rowIndex);??
  • ????????return?row;??
  • ????}??
  • ??
  • ??????
  • ??
  • }??

  • 不過,值得高興的是,這個bug已經在POI-3.12的版本解決了

    總結

    以上是生活随笔為你收集整理的(6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug...的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: аⅴ天堂中文在线网 | 欧美日本在线观看 | 欧美日本国产在线 | 午夜视频入口 | 内射合集对白在线 | 中文字幕第五页 | 亚洲+小说+欧美+激情+另类 | 中国黄色三级视频 | 日免费视频 | 免费成人在线网站 | 欧美色婷婷 | 黄色aaaaa | 男人的天堂网在线 | 国产日韩网站 | 在线精品亚洲欧美日韩国产 | 国产综合社区 | 毛片在线不卡 | 情侣黄网站免费看 | 99福利在线 | 韩国三级做爰视频 | 精品综合 | 电影《两个尼姑》免费播放 | 色就是色欧美色图 | 91美女视频在线观看 | 在线成人免费 | 99精品久久精品一区二区 | 成人勉费视频 | 成人一级黄色 | 久久免费看少妇 | 黄色小视屏 | 男女国产视频 | 极品新婚夜少妇真紧 | 成年人看的网站 | 亚洲日本黄色 | 五月婷婷一区 | 欧美日韩中文字幕视频 | 五月天啪啪 | av毛片在线免费观看 | 91吃瓜今日吃瓜入口 | 精品福利一区二区 | 欧美日韩三级视频 | 日韩蜜桃视频 | 美女黄18以下禁止观看 | 一区二区三区视频在线观看免费 | 亚洲国产日韩一区二区 | 26uuu成人网| 日日爽视频 | 成人第一页 | 91老司机在线 | 欧美三级自拍 | www.-级毛片线天内射视视 | www.久久色 | 67194成人在线观看 | 日韩一区二区三区久久 | 成人免费毛片足控 | 艳妇臀荡乳欲伦交换在线看 | 涩涩视频免费观看 | 制服一区| 黄色一级片av | 国产原创在线视频 | 日韩黄色免费看 | 天堂8在线 | 亚洲国产福利视频 | 亚洲成熟少妇视频在线观看 | 91视频专区| 国产视频二区 | 久久成人激情 | 九九九久久久精品 | 嫩草影院懂你的影院 | 日韩欧美亚洲一区二区 | 一本久道综合色婷婷五月 | 久久国精品 | 黄色香蕉网站 | 蜜桃av鲁一鲁一鲁一鲁俄罗斯的 | 亚洲av熟女国产一区二区性色 | 亚洲区成人 | 一起操17c | 国产一区亚洲二区三区 | 日韩性av| 成 人免费va视频 | 欧美激情国产日韩精品一区18 | 久久精品tv| 欧美黑人巨大xxx极品 | 国产在线播放一区二区 | 乱lun合集小可的奶水 | xxxxwww一片 | 免费一级suv好看的国产网站 | 久久av资源 | 欧美日韩一区二区三区四区 | 久久久久99精品 | 免费看又黄又无码的网站 | 神马午夜电影一区二区三区在线观看 | 欧美片免费网站 | 爱爱视频在线播放 | 欧美巨大另类极品videosbest | 婷婷丁香社区 | 我会温柔一点的日剧 | 深夜福利免费视频 | 国产高清不卡 |