本文檔適用于有一定開發(fā)經(jīng)驗和擅于思考的人閱讀!
只要有表格,就會有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./poi/
如果沒有找到包的朋友,可以加我的 QQ:107213911(24小時在線) 或者郵件聯(lián)系 hehai.520@163.com
免費放送!
操作Excel的原理大體是這樣:
1.創(chuàng)建一個Excel文件
2.讀取Excel文件
3.進(jìn)行讀出和寫入操作
應(yīng)該就這么簡單!
網(wǎng)上有此類文檔,不過沒有我的完全,可以將示例:CreateXL.java 直接放在工程下即可運行!
也可以根據(jù)自己需要更改.
示例中有關(guān)于表名設(shè)置為中文的問題遲遲沒有解決,望大蝦們指點.
這是本人第一次在網(wǎng)上發(fā)布文檔,很希望朋友們多意見!
也希望站長指正后發(fā)布!
可能表述有些問題,如有不明白的朋友,請聯(lián)系我!
示例: CreateXL.java
/**
* Copyright by 2006 A&D.
* writer: hike.
*/
package comm;
//如需設(shè)置字體,請導(dǎo)入以下兩個包
//import org.apache.poi.hssf.usermodel.HSSFCellStyle;
//import org.apache.poi.hssf.usermodel.HSSFFont;
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.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
public class CreateXL {
/**
*
*解決中文問題
*/
public static String getUnicode(String toEncoded,String encoding){
String retString="";
if(toEncoded.equals("")||toEncoded.trim().equals(""))
{
return toEncoded;
}
try
{
byte[] b=toEncoded.getBytes(encoding);
sun.io.ByteToCharConverter convertor=sun.io.ByteToCharConverter.getConverter(encoding);
char [] c=convertor.convertAll(b);
for(int i=0;i< c.length;i++)
{
retString+=String.valueOf(c[i]);
}
}catch(java.io.UnsupportedEncodingException usee)
{
System.out.println("不支持"+encoding+"編碼方式");
usee.printStackTrace();
}catch(sun.io.MalformedInputException mfie)
{
System.out.println("輸入?yún)?shù)無效!!!");
mfie.printStackTrace();
}
return retString;
}
/**
* 寫入EXCEL
*/
//Excel 文件要存放的位置,假定在D盤JTest目錄下
public static String UPath="D:\\JTest";
//工作簿名稱,可以取中文(就是另存為名稱).
public static String outputFile="D:/JTest/test.xls";
public static void main(String argv[]){
try{
// 如果UPath不存在,則創(chuàng)建路徑
if(!new java.io.File(UPath).isDirectory()){
new java.io.File(UPath).mkdirs();
}
File objFile = new File(outputFile);
HSSFWorkbook workbook = null;
HSSFSheet sheet = null;
String table_name = "sheet1";
//創(chuàng)建文件
if(!objFile.exists()){ //文件不存在
//創(chuàng)建新的Excel 工作簿
System.out.println("檢測到文件不存在,正在創(chuàng)建文件...");
workbook = new HSSFWorkbook();
//在Excel工作簿中建一工作表,其名為缺省值
//如要新建一名為"效益指標(biāo)"的工作表,其語句為:
//HSSFSheet sheet = workbook.createSheet("效益指標(biāo)");
//上一句是來自網(wǎng)上,其實表名并不支持中文,轉(zhuǎn)換后也不行!
//如有人已解決,請給出,謝謝!
sheet = workbook.createSheet(table_name);
//新建一輸出文件流
FileOutputStream fOut = new FileOutputStream(outputFile);
//把相應(yīng)的Excel 工作簿存盤
workbook.write(fOut);
fOut.flush();
//操作結(jié)束,關(guān)閉文件
fOut.close();
}
//如果文件存在,將直接插入數(shù)據(jù).
//創(chuàng)建對Excel工作簿文件的引用
workbook = new HSSFWorkbook(new FileInputStream(outputFile));
//創(chuàng)建對工作表的引用。
//本例是按名引用(讓我們假定那張表有著缺省名"Sheet1")
sheet = workbook.getSheet(table_name);
//也可用getSheetAt(int index)按索引引用,
//在Excel文檔中,第一張工作表的缺省索引是0,
//其語句為:HSSFSheet sheet = workbook.getSheetAt(0);
//讀取左上端單元
//行和列都是以‘0‘開頭,比如A1為‘00‘
for(int i=0; i< 2; i++){
for(int j=0; j< 5; j++){
//這兒,你可以測試讀出一個已存在文件
//HSSFRow row = sheet.getRow(i);
//HSSFCell cell = row.getCell((short)j);
//輸出單元內(nèi)容,cell.getStringCellValue()就是取所在單元的值
//System.out.println("左上端單元是: " + cell.getStringCellValue());
//在索引0的位置創(chuàng)建行(最頂端的行)
//這兒,測試插入數(shù)據(jù)
//插入之前必需先創(chuàng)建
HSSFRow row = sheet.createRow((short)i);
//在索引0的位置創(chuàng)建單元格(左上端)
HSSFCell cell = row.createCell((short)j);
//在創(chuàng)建之后可以設(shè)置單元格格式
//具體用法將附于文檔后面.
//記得要導(dǎo)入包
//定義單元格為字符串類型
//這兩名非常重要,缺少,則不能顯示中文,
//即使你調(diào)用編碼轉(zhuǎn)換方法,也不行.
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
//指定編碼格式
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
//在單元格中輸入一些內(nèi)容
String text = ""+i+j+"";
//調(diào)用編碼轉(zhuǎn)換方法,只針對中文
text = getUnicode(text,"gb2312");
cell.setCellValue(text);
//新建一輸出文件流
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 );
}
}
}
設(shè)置單元格格式
在這里,我們將只介紹一些和格式設(shè)置有關(guān)的語句,
我們假定workbook就是對一個工作簿的引用。在Java中,
第一步要做的就是創(chuàng)建和設(shè)置字體和單元格的格式,然后再應(yīng)用這些格式:
例用開發(fā)工具追蹤器,可以查看更多參數(shù),自己慢慢去研究!
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)題");