Excel報表的方法,一個過於簡單,一個只能用於window平台(因為使用jdbc-odbc bridge),且無法使用到Excel內部的各種公式或是方法,因此,今天介紹一個apache(Unix平台最流行的WEB服務器平台)出的元件叫POI,它可以在UNIX或window平台處理word或Excel檔案,而不需要依靠window的com,並且可設定儲存格格式、列印格式等等;今天我來介紹其中有關資料讀取、新增、修改及刪除的功能,若各位網友研究好其他的功能,麻煩Email給我([email protected]),分享給大家!
一、需要用的檔案:jakarta-poi-1.8.0-dev-20020917.jar
幾乎每天都有1.8.0的最新版(但非正式版),正式的版本是1.5.0
http://jakarta.apache(Unix平台最流行的WEB服務器平台).org/builds/jakarta-poi/nightly/
將檔案復制到classpath所指到的地方
二、有興趣的朋友可以參考
http://jakarta.apache(Unix平台最流行的WEB服務器平台).org/poi/
三、先建立一個叫做book1.xls的Excel檔,內容如下
----------------------------------
項目 單價 數量 合計
CPU 7000 5 35000
硬碟 2500 2 5000
記憶體 1600 3 4800
----------------------------------
其中合計的欄位是設定公式,單價*數量
四、資料讀取範例
<%@ page contentType="text/html;charset=MS950" import="java.util.*,java.io.*" %>
<%@ page import="org.apache(Unix平台最流行的WEB服務器平台).poi.poifs.filesystem.*,org.apache(Unix平台最流行的WEB服務器平台).poi.hssf.usermodel.*" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=MS950">
<title>讀取Excel檔案</title>
</head>
<body>
<table border="1" width="100%">
<%
FileInputStream finput = new FileInputStream(application.getRealPath("/")+"book1.xls" );
//設定FileINputStream讀取Excel檔
POIFSFileSystem fs = new POIFSFileSystem( finput );
HSSFWorkbook wb = new HSSFWorkbook(fs);
HSSFSheet sheet = wb.getSheetAt(0);
//讀取第一個工作表,宣告其為sheet
finput.close();
HSSFRow row=null;
//宣告一列
HSSFCell cell=null;
//宣告一個儲存格
short i=0;
short y=0;
//以巢狀迴圈讀取所有儲存格資料
for (i=0;i<=sheet.getLastRowNum();i++)
{
out.println("<tr>");
row=sheet.getRow(i);
for (y=0;y<row.getLastCellNum();y++)
{
cell=row.getCell(y);
out.print("<td>");
//判斷儲存格的格式
switch ( cell.getCellType() )
{
case HSSFCell.CELL_TYPE_NUMERIC:
out.print(cell.getNumericCellValue());
//getNumericCellValue()會回傳double值,若不希望出現小數點,請自行轉型為int
break;
case HSSFCell.CELL_TYPE_STRING:
out.print( cell.getStringCellValue());
break;
case HSSFCell.CELL_TYPE_FORMULA:
out.print(cell.getNumericCellValue());
//讀出公式儲存格計算後的值
//若要讀出公式內容,可用cell.getCellFormula()
break;
default:
out.print( "不明的格式");
break;
}
out.println("</td>");
}
out.println("</tr>");
}
%>
</table>
</body>
</html>
五、資料新增範例
<%@ page contentType="text/html;charset=MS950" import="java.util.*,java.io.*" %>
<%@ page import="org.apache(Unix平台最流行的WEB服務器平台).poi.poifs.filesystem.*,org.apache(Unix平台最流行的WEB服務器平台).poi.hssf.usermodel.*" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=MS950">
<title>插入資料至Excel檔案</title>
</head>
<body>
<%
FileInputStream finput = new FileInputStream(application.getRealPath("/")+"book1.xls" );
//設定FileINputStream讀取Excel檔
POIFSFileSystem fs = new POIFSFileSystem( finput );
HSSFWorkbook wb = new HSSFWorkbook(fs);
HSSFSheet sheet = wb.getSheetAt(0);
//讀取第一個工作表,宣告其為sheet
finput.close();
HSSFRow row=null;
//宣告一列
HSSFCell cell=null;
//宣告一個儲存格
short i=4;
row=sheet.createRow(i);
//建立一個新的列,注意是第五列(列及儲存格都是從0起算)
cell=row.createCell((short)0);
cell.setEncoding(HSSFCell.ENCODING_UTF_16);
//設定這個儲存格的字串要儲存雙位元
cell.setCellValue("顯示卡");
cell=row.createCell((short)1);
cell.setCellValue(1700);
cell=row.createCell((short)2);
cell.setCellValue(8);
cell=row.createCell((short)3);
//設定這個儲存格為公式儲存格,並輸入公式
cell.setCellFormula("B"+(i+1)+"*C"+(i+1));
try
{
FileOutputStream fout=new FileOutputStream(application.getRealPath("/")+"book1.xls");
wb.write(fout);
//儲存
fout.close();
out.println("儲存成功<a href=book1.xls>book1.xls</a>");
}
catch(IOException e)
{
out.println("產生錯誤,錯誤訊息:"+e.toString());
}
%>
</body>
</html>
六、資料刪除、修改範例
<%@ page contentType="text/html;charset=MS950" import="java.util.*,java.io.*" %>
<%@ page import="org.apache(Unix平台最流行的WEB服務器平台).poi.poifs.filesystem.*,org.apache(Unix平台最流行的WEB服務器平台).poi.hssf.usermodel.*" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=MS950">
<title>刪除、修改資料至Excel檔案</title>
</head>
<body>
<%
FileInputStream finput = new FileInputStream(application.getRealPath("/")+"book1.xls" );
//設定FileINputStream讀取Excel檔
POIFSFileSystem fs = new POIFSFileSystem( finput );
HSSFWorkbook wb = new HSSFWorkbook(fs);
HSSFSheet sheet = wb.getSheetAt(0);
//讀取第一個工作表,宣告其為sheet
finput.close();
HSSFRow row=null;