亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

讓POI架起Java與Office之間的橋梁三

2019-11-18 12:27:01
字體:
來源:轉載
供稿:網友

  main()方法利用POIFS的事件系統從命令行指定的OLE 2文檔讀取名為/005SummaryInformation的流,當POIFSReader 碰到這個流時,它把控制傳遞給MyPOIFSReaderListener的PRocessPOIFSReaderEvent()方法。
  
  processPOIFSReaderEvent()到底有什么用呢?它通過參數獲得一個輸入流,該輸入流包含了文檔標題等屬性。為了訪問文檔的屬性,我們從輸入流創建一個PropertySet實例,如下所示:
  
  si = (SummaryInformation) PropertySetFactory.create(event.getStream());
  
  這個語句其實包含三個步驟的操作:
  
  ◆ event.getStream()從POIFSReader傳入的POIFSReaderEvent獲得輸入流。
  
  ◆ 以剛才獲得的輸入流為參數,調用PropertySetFactory的靜態方法create()。正如其名字所暗示的,PropertySetFactory是一個工廠類,它有一臺“機器”能夠把一個輸入流轉換成一個PropertySet實例,這臺機器就是create()方法。
  
  ◆ 把create()方法返回的PropertySet定型(cast)成為SummaryInformation。PropertySet提供了按照一般辦法讀取屬性集的各種機制,SummaryInformation是PropertySet的子類,即SummaryInformation類在PropertySet類的基礎上增加了操作Microsoft標準屬性的便捷方法。
  
  在這個處理過程中,可能引起錯誤的因素很多,因此我們把這部分內容放入了一個try塊,不過這個示例程序只按照最簡單的方式處理了異常,在實際應用中,最好能夠對可能出現的不同異常類型分別處理。
  
  除了一般的I/O異常之外,還有可能碰到HPSF特有的異常,例如,假如輸入流不包含屬性集或屬性集非法,就會拋出NoPropertySetStreamException異常。
  
  有一種錯誤不太常見,但也不是絕無可能/005SummaryInformation包含一個合法的屬性集,但不是摘要信息屬性集。假如出現這種情況,則定型成SummaryInformation操作會失敗,引發ClassCastException異常。
  
  獲得SummaryInformation實例之后,剩下的事情就很簡單了,只要調用getTitle()方法,然后輸出結果。
  
  除了getTitle()之外,SummaryInformation還包含其他一些便捷方法,例如getapplicationName()、getAuthor()、getCharCount()、和getCreateDateTime()等。HPSF的javaDoc文檔具體說明了所有這些方法。
  
  八、文檔摘要信息
  
  遺憾的是,并非所有的屬性都保存在摘要信息屬性集之中。許多(但不是全部)OLE 2文件還有另一個屬性集,稱為“文檔摘要信息”,對應的流是/005DocumentSummaryInformation。這個屬性集保存的屬性包括文檔的類別、Powerpoint幻燈的多媒體剪輯數量,等等。
  
  要訪問文檔摘要信息屬性集,程序的處理過程也和上例相似,只是注冊的目標應該改成/005DocumentSummaryInformation有時,你可能想要同時注冊到摘要信息和文檔摘要信息這兩個流。其余的處理方式和前面的例子差不多,你應該把包含文檔摘要信息的流傳遞給PropertySetFactory.create(),但這次工廠方法將返回一個DocumentSummaryInformation對象(而不是前面例子中的SummaryInformation對象)。
  
  假如同時注冊到了兩個流,注重檢查返回值的具體類型,或者使用Java的instanceof操作符,或者使用專用的isSummaryInformation()和isDocumentSummaryInformation()方法。記住,create()方法返回的總是一個PropertySet對象,因此你總是可以對create()返回對象調用isSummaryInformation()和isDocumentSummaryInformation()方法,PropertySet類之所以要提供這兩個方法,是因為屬性集可能是自定義的。
  
  假如你想要處理自定義的屬性集,或者要從標準的屬性集讀取用戶定義的屬性,必須使用一個更一般化的API,前面已經提到,這個API要復雜得多,本文不再討論,請參見HPSF的HOW-TO文檔和POI的文檔。
  
  結束語:本文探討了HSSF的應用以及如何輸出到Excel文件,另外還涉及了HPSF以及如何讀取屬性集文檔摘要信息。POI是一個功能非常強大的項目,許多主題本文尚未涉及,例如如何用HSSF Serializer將xml文檔轉換成Excel格式等,這一切仍有待您去研究了。
  
  九、附錄
  
  實例:利用Servlet創建和返回一個工作簿。
  
  package org.apache.poi.hssf.usermodel.examples;
  
  import java.io.*;
  import java.net.*;
  import javax.servlet.*;
  import javax.servlet.http.*;
  import org.apache.poi.hssf.usermodel.*;
  
  public class HSSFCreate extends HttpServlet {
  public void init(ServletConfig config)
  throws ServletException {
  super.init(config);
  }
  
  public void destroy() {
  }
  
  /** 處理HTTP GET 和POST請求
  * @param request:請求
  * @param response:應答
  */
  protected void processRequest(HttpServletRequest request,
  HttpServletResponse response)
  throws ServletException, IOException {
  
  response.setContentType("application/vnd.ms-excel");
  HSSFWorkbook wb = new HSSFWorkbook();
  HSSFSheet sheet = wb.createSheet("new sheet");
  
  // 創建一個新的行,添加幾個單元格。
  // 行號從0開始計算
  HSSFRow row   = sheet.createRow((short)0);
  // 創建一個單元格,設置單元格的值
  HSSFCell cell  = row.createCell((short)0);
  cell.setCellValue(1);
  
  row.createCell((short)1).setCellValue(1.2);
  row.createCell((short)2).setCellValue("一個字符串值");
  row.createCell((short)3).setCellValue(true);
  // 寫入輸出結果
  OutputStream out = response.getOutputStream();
  wb.write(out);
  out.close();
  }
  
  /** 處理HTTP GET請求
  * @param request:請求
  * @param response:應答
  */
  protected void doGet(HttpServletRequest request,
  HttpServletResponse response)
  throws ServletException, IOException {
  processRequest(request, response);
  }
  
  /** 處理HTTP POST請求
  * @param request:請求
  * @param response:應答
  */
  protected void doPost(HttpServletRequest request,
  HttpServletResponse response)
  throws ServletException, IOException {
  processRequest(request, response);
  }
  
  /** 返回關于Servlet的簡單說明
  */
  public String getServletInfo() {
  return "示例:在Servlet中用HSSF創建Excel工作簿";
  }
  }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
青青草原成人在线视频| 一区二区三区美女xx视频| 91黑丝在线观看| 亚洲国产一区二区三区四区| 久久精品国产亚洲| 欧美性高潮床叫视频| 日韩黄色高清视频| 久久精品国产免费观看| 欧美另类高清videos| 日韩高清电影免费观看完整版| 亚洲第一男人av| 美女999久久久精品视频| 日韩精品一二三四区| 欧美在线一级va免费观看| 浅井舞香一区二区| 国产精品第二页| 性欧美xxxx视频在线观看| 高跟丝袜一区二区三区| 亚洲片在线观看| 国内精品视频一区| 97国产精品视频| 欧美成年人视频网站| 日韩成人小视频| 久久久精品在线观看| 国模私拍一区二区三区| 91伊人影院在线播放| 日韩在线不卡视频| 日av在线播放中文不卡| 2019最新中文字幕| 日本视频久久久| 亚洲高清久久网| 奇米4444一区二区三区| 91黑丝在线观看| 日韩美女在线观看一区| 欧美日韩中文字幕在线| 亚洲人成网站777色婷婷| 亚洲欧美日韩爽爽影院| 亚洲影院污污.| 欧美激情精品久久久久久| 亚洲国产小视频在线观看| 日av在线播放中文不卡| 亚洲欧美日韩天堂| 午夜精品久久久久久99热| 日韩免费电影在线观看| 国产福利视频一区| 国产精品欧美久久久| 欧美极品少妇xxxxⅹ喷水| 亚洲欧洲国产伦综合| 91网在线免费观看| 视频在线观看99| 97国产精品人人爽人人做| 91超碰caoporn97人人| 日韩中文字幕在线观看| 日韩精品在线观看一区| 欧美大片免费观看在线观看网站推荐| 日韩av免费在线观看| 亚洲加勒比久久88色综合| 国产视频久久久久久久| 午夜精品久久久久久久久久久久| 91国在线精品国内播放| 日韩精品中文在线观看| 欧美肥臀大乳一区二区免费视频| 97香蕉久久超级碰碰高清版| 亚洲精品视频免费| 国产91精品黑色丝袜高跟鞋| 日韩亚洲在线观看| 欧美影院成年免费版| 亚洲成人网久久久| 91九色视频导航| 欧美激情久久久久| 久久人人爽人人爽人人片av高请| 日韩av最新在线观看| 97精品久久久中文字幕免费| 人人澡人人澡人人看欧美| 国产成人高清激情视频在线观看| 97在线精品国自产拍中文| 97热精品视频官网| 疯狂做受xxxx高潮欧美日本| 在线播放日韩精品| 亚洲变态欧美另类捆绑| 国语对白做受69| 成人午夜一级二级三级| 日本午夜精品理论片a级appf发布| 欧美午夜电影在线| 欧美怡红院视频一区二区三区| 日韩精品视频三区| 92福利视频午夜1000合集在线观看| 日韩av在线网页| 国产丝袜一区视频在线观看| 日韩欧美精品在线观看| 亚洲美女久久久| 国产成人精品久久二区二区| 亚洲欧美一区二区三区在线| 精品国产依人香蕉在线精品| 亚洲精品乱码久久久久久金桔影视| 久久久国产精彩视频美女艺术照福利| 久久久久久久av| 久久艳片www.17c.com| 亚洲精品国产美女| 日韩成人激情视频| 国产手机视频精品| 欧美片一区二区三区| 亚洲欧美在线看| 国产精国产精品| 国产精品久久久久福利| 欧美香蕉大胸在线视频观看| 亚洲成色777777女色窝| 欧美在线亚洲一区| 精品久久中文字幕久久av| 欧美xxxx做受欧美.88| 国产精品网址在线| 国产精品福利在线观看网址| 国产精品久久久久久婷婷天堂| 国产精品偷伦免费视频观看的| 57pao国产精品一区| 精品国产福利在线| 国产精品精品一区二区三区午夜版| 3344国产精品免费看| 91精品免费看| 国产精品va在线播放| 日韩电影中文字幕在线观看| 日韩av123| 中文字幕欧美视频在线| 欧美激情欧美激情在线五月| 亚洲男人天堂手机在线| 亚洲天堂第一页| 日韩av大片在线| 国产精品爱久久久久久久| 欧美亚洲午夜视频在线观看| 亚洲一区二区中文| 日韩av在线免播放器| 国产精彩精品视频| 国产精品免费视频久久久| xx视频.9999.com| 国产精品久久久久免费a∨| 96pao国产成视频永久免费| 欧美日韩国产色| 日韩a**中文字幕| 欧美性猛交xxxx乱大交| 精品人伦一区二区三区蜜桃网站| 亚洲人成电影网站色www| 在线看日韩av| 欧美黄色片视频| 在线观看日韩www视频免费| 91在线观看欧美日韩| 国产日韩欧美在线| 亚洲国产高清福利视频| 九九热精品视频国产| 91免费国产网站| 亚洲va久久久噜噜噜久久天堂| 中文字幕亚洲欧美日韩在线不卡| 超碰91人人草人人干| 国产精品久久久久久av| 日韩在线精品视频| 欧美日韩在线一区| 热99精品只有里视频精品| 成人免费视频网址| 日本久久久久久久| 国产亚洲成精品久久| 色与欲影视天天看综合网| 欧美电影免费观看高清完整| 国产精品激情av电影在线观看| 伊人伊成久久人综合网小说| 亚洲欧美日本另类|