隨筆-86  評(píng)論-767  文章-3  trackbacks-3
          ? 為了保證示例程序的運(yùn)行,必須安裝Java 2 sdk1.4.0 和Jakarta POI,Jakarta POI的Web站點(diǎn)是: http://jakarta.apache.org/poi/

          示例1將演示如何利用Jakarta POI API 創(chuàng)建Excel 文檔。


          示例1程序如下:
          import org.apache.poi.hssf.usermodel.HSSFWorkbook;
          import org.apache.poi.hssf.usermodel.HSSFSheet;
          import org.apache.poi.hssf.usermodel.HSSFRow;
          import org.apache.poi.hssf.usermodel.HSSFCell;
          import java.io.FileOutputStream;
          public class CreateXL {
           /** Excel 文件要存放的位置,假定在D盤JTest目錄下*/
           public static String outputFile="D:/JTest/ gongye.xls";
           public static void main(String argv[])
          ? {
           try
          ? {
            // 創(chuàng)建新的Excel 工作簿
            HSSFWorkbook workbook = new HSSFWorkbook();
            // 在Excel工作簿中建一工作表,其名為缺省值
            // 如要新建一名為"效益指標(biāo)"的工作表,其語句為:
            // HSSFSheet sheet = workbook.createSheet("效益指標(biāo)");
            HSSFSheet sheet = workbook.createSheet();
            // 在索引0的位置創(chuàng)建行(最頂端的行)
            HSSFRow row = sheet.createRow((short)0);
            //在索引0的位置創(chuàng)建單元格(左上端)
            HSSFCell cell = row.createCell((short) 0);
            // 定義單元格為字符串類型
            cell.setCellType(HSSFCell.CELL_TYPE_STRING);
            // 在單元格中輸入一些內(nèi)容
            cell.setCellValue("增加值");
            // 新建一輸出文件流
            FileOutputStream fOut = new FileOutputStream(outputFile);
            // 把相應(yīng)的Excel 工作簿存盤
            workbook.write(fOut);
            fOut.flush();
            // 操作結(jié)束,關(guān)閉文件
            fOut.close();
            System.out.println("文件生成...");


           }catch(Exception e) {
            System.out.println("已運(yùn)行 xlCreate() : " + e );
           }
          }
          }


          讀取Excel文檔中的數(shù)據(jù)
            示例2將演示如何讀取Excel文檔中的數(shù)據(jù)。假定在D盤JTest目錄下有一個(gè)文件名為gongye.xls的Excel文件。
            示例2程序如下:
          import org.apache.poi.hssf.usermodel.HSSFWorkbook;
          import org.apache.poi.hssf.usermodel.HSSFSheet;
          import org.apache.poi.hssf.usermodel.HSSFRow;
          import org.apache.poi.hssf.usermodel.HSSFCell;
          import java.io.FileInputStream;
          public class ReadXL {
           /** Excel文件的存放位置。注意是正斜線*/
           public static String fileToBeRead="D:/JTest/ gongye.xls";
           public static void main(String argv[]){
           try{
            // 創(chuàng)建對(duì)Excel工作簿文件的引用
            HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(fileToBeRead));
            // 創(chuàng)建對(duì)工作表的引用。
            // 本例是按名引用(讓我們假定那張表有著缺省名"Sheet1")
            HSSFSheet sheet = workbook.getSheet("Sheet1");
            // 也可用getSheetAt(int index)按索引引用,
            // 在Excel文檔中,第一張工作表的缺省索引是0,
            // 其語句為:HSSFSheet sheet = workbook.getSheetAt(0);
            // 讀取左上端單元
            HSSFRow row = sheet.getRow(0);
            HSSFCell cell = row.getCell((short)0);
            // 輸出單元內(nèi)容,cell.getStringCellValue()就是取所在單元的值
            System.out.println("左上端單元是: " + cell.getStringCellValue());
           }catch(Exception e) {
            System.out.println("已運(yùn)行xlRead() : " + e );
           }
          }
          }



            設(shè)置單元格格式
            在這里,我們將只介紹一些和格式設(shè)置有關(guān)的語句,我們假定workbook就是對(duì)一個(gè)工作簿的引用。在Java


          中,第一步要做的就是創(chuàng)建和設(shè)置字體和單元格的格式,然后再應(yīng)用這些格式:


            1、創(chuàng)建字體,設(shè)置其為紅色、粗體:
          HSSFFont font = workbook.createFont();
          font.setColor(HSSFFont.COLOR_RED);
          font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
            2、創(chuàng)建格式
          HSSFCellStyle cellStyle= workbook.createCellStyle();
          cellStyle.setFont(font);
            3、應(yīng)用格式
          HSSFCell cell = row.createCell((short) 0);
          cell.setCellStyle(cellStyle);
          cell.setCellType(HSSFCell.CELL_TYPE_STRING);
          cell.setCellValue("標(biāo)題 ");


            總之,如本篇文章所演示的一樣,Java程序員不必?fù)?dān)心Excel工作表中的數(shù)據(jù)了,利用Jakarta POI API,


          我們就可以輕易的在程序中存取Excel文檔。

          posted on 2005-01-14 15:07 eamoi 閱讀(586) 評(píng)論(0)  編輯  收藏

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 宿松县| 鲜城| 微山县| 宜兴市| 司法| 朝阳市| 土默特左旗| 莱州市| 太谷县| 嘉峪关市| 中江县| 宕昌县| 南郑县| 应城市| 塔城市| 巨野县| 天峻县| 平湖市| 荔浦县| 宜宾县| 顺义区| 安图县| 固阳县| 营口市| 山东省| 博爱县| 无锡市| 赤峰市| 嵩明县| 剑河县| 桐梓县| 新龙县| 浮山县| 鄯善县| 元阳县| 临汾市| 南漳县| 新竹县| 云霄县| 固原市| 武邑县|