隨筆 - 12  文章 - 0  trackbacks - 0
          <2007年6月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          1234567

          常用鏈接

          我參與的團隊

          隨筆檔案

          搜索

          •  

          最新評論

          閱讀提示:只要有表格,就會有Microsoft Excel,用Microsoft Excel處理數(shù)據(jù)已成為不少人的習(xí)慣。Jakarta POI API就為Java程序員提供了一條存取Microsoft文檔格式的神奇之路,其中最成熟的就是能存取Microsoft Excel文檔的HSSF API。本篇文章就舉例示范如何利用Java 創(chuàng)建和讀取Excel文檔,并設(shè)置單元格的字體和格式。
          只要有表格,就會有Microsoft Excel,用Microsoft Excel處理數(shù)據(jù)已成為不少人的習(xí)慣。Jakarta POI API就為Java程序員提供了一條存取Microsoft文檔格式的神奇之路,其中最成熟的就是能存取Microsoft Excel文檔的HSSF API。

          本篇文章就舉例示范如何利用Java 創(chuàng)建和讀取Excel文檔,并設(shè)置單元格的字體和格式。

          為了保證示例程序的運行,必須安裝Java 2 sdk1.4.0 和Jakarta POI,Jakarta POI的Web站點是: http://jakarta.apache.org/poi/

          創(chuàng)建Excel 文檔

          示例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("已運行 xlCreate() : " + e );

           }

          }

          }

          讀取Excel文檔中的數(shù)據(jù)

          示例2將演示如何讀取Excel文檔中的數(shù)據(jù)。假定在D盤JTest目錄下有一個文件名為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)建對Excel工作簿文件的引用

          HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(fileToBeRead));

          // 創(chuàng)建對工作表的引用。

          // 本例是按名引用(讓我們假定那張表有著缺省名"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("已運行xlRead() : " + e );

           }

          }

          }

          設(shè)置單元格格式

          在這里,我們將只介紹一些和格式設(shè)置有關(guān)的語句,我們假定workbook就是對一個工作簿的引用。在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)題 ");

          posted on 2007-06-26 15:10 天問 閱讀(311) 評論(0)  編輯  收藏

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


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 宣化县| 饶河县| 太仓市| 苏州市| 炉霍县| 丽江市| 岫岩| 沙田区| 额敏县| 米泉市| 墨竹工卡县| 海林市| 大名县| 牟定县| 利津县| 景泰县| 石屏县| 通化市| 临湘市| 嘉兴市| 阿坝县| 磴口县| 缙云县| 井研县| 桃园县| 出国| 项城市| 勐海县| 米林县| 互助| 黎城县| 涞源县| 盘锦市| 论坛| 盐池县| 连平县| 汝阳县| 山阴县| 平武县| 万年县| 房山区|