上次談過了使用iText產生PDF檔,這次換成來談談使用JExcel來產生EXCEL檔的方法。
首先,先到他的SourceForge主頁面download相關的API檔案。
http://sourceforge.net/projects/jexcelapi/
或
http://www.andykhan.com/jexcelapi/download.html
當然,他也是OpenSource的元件。
下列為其Tutorial教學:
http://www.andykhan.com/jexcelapi/tutorial.html
一切就緒後,那就準備上路了。
下載下來的壓縮檔解開後,可以找到jxl.jar,先將此檔案加入你的Classpath中吧!
1. 先建立Workbook
也就是整份的Excel檔案,可指定檔名。
Workbook workbook = Workbook.getWorkbook(new File("test.xls"));
2. 建立Sheet
也就是每個Excel檔案下面可以跳tag的sheet表。
Sheet sheet = workbook.createSheet("我的Excel表", 0);
第一個參數是sheet name,第二個參數是第幾張sheet,當然index是由0開始算。
3. 建立字型
WritableFont chFont11w = new WritableFont(WritableFont.TIMES, 11);
chFont11w.setColour(Colour.WHITE);
先建立一個WritableFont的instance,其constructor的第一個參數是指定字型,第二個是字型大小。
其中字型的部份,可以使用WritableFont所提供預設的一堆static常數來指定,
也可以直接輸入string,比如打"標楷體",到時產生的字型就會依照你所指定的來顯示。
而setColour是指定此字型的顏色,這個部份就麻煩。
(由colour這個字來看,很顯然的JExcel應是英國相關的人開發的:P 反正總之不會是美國)
顏色為什麼麻煩呢?在JExcel裡面,Colour class並不提供public constructor讓user自己指定RGB的顏色,
所以你只能從Colour中一堆的static常數顏色來指定,之前為了這個問題還研究了一下他的原始碼,
果然是不行,他的constructor是protected的,就連繼承之後雖然可以指定rgb顏色,但是仍然沒有作用。
(後來我看了一下Excel,發現原來這是因為Excel的標準調色盤就那些顏色
不像Word一樣可以讓使用者自訂顏色的關係)
查API doc就可以看到,他提供的顏色有:
static Colour AQUA
static Colour AUTOMATIC
static Colour BLACK
static Colour BLUE
static Colour BLUE_GREY
static Colour BLUE2
static Colour BRIGHT_GREEN
static Colour BROWN
static Colour CORAL
static Colour DARK_BLUE
static Colour DARK_BLUE2
static Colour DARK_GREEN
static Colour DARK_PURPLE
static Colour DARK_RED
static Colour DARK_RED2
static Colour DARK_TEAL
static Colour DARK_YELLOW
static Colour DEFAULT_BACKGROUND
static Colour DEFAULT_BACKGROUND1
static Colour GOLD
static Colour GRAY_25
static Colour GRAY_50
static Colour GRAY_80
static Colour GREEN
static Colour GREY_25_PERCENT
static Colour GREY_40_PERCENT
static Colour GREY_50_PERCENT
static Colour GREY_80_PERCENT
static Colour ICE_BLUE
static Colour INDIGO
static Colour IVORY
static Colour LAVENDER
static Colour LIGHT_BLUE
static Colour LIGHT_GREEN
static Colour LIGHT_ORANGE
static Colour LIGHT_TURQUOISE
static Colour LIGHT_TURQUOISE2
static Colour LIME
static Colour OCEAN_BLUE
static Colour OLIVE_GREEN
static Colour ORANGE
static Colour PALE_BLUE
static Colour PALETTE_BLACK
static Colour PERIWINKLE
static Colour PINK
static Colour PINK2
static Colour PLUM
static Colour PLUM2
static Colour RED
static Colour ROSE
static Colour SEA_GREEN
static Colour SKY_BLUE
static Colour TAN
static Colour TEAL
static Colour TEAL2
static Colour TURQOISE2
static Colour TURQUOISE
static Colour UNKNOWN
static Colour VERY_LIGHT_YELLOW
static Colour VIOLET
static Colour VIOLET2
static Colour WHITE
static Colour YELLOW
static Colour YELLOW2
上面列了這麼多,哪知道哪一個真正的顏色是怎麼樣?
除非自己邊試邊換才知,這太麻煩了,我寫了一隻程式把所有的顏色都印出來:
好了,但問題來了,上面提供的顏色如果對比較龜毛的人而言(比如我...),
一定是不足使用的,但如剛剛上述說的,Colour不提供自訂顏色的功能,
後來找了老半天文件,終於找到一個可以用的方式,
就是在workbook中,提供了一個setColourRGB的method,
但這個method並不是設定新的顏色,而是可以把上述提供的顏色重新覆寫其RGB設定值,
這個方法雖然不是挺好,但是終於有救了!
所以你就找個顏色來開刀,例如:
workbook.setColourRGB(Colour.DARK_GREEN, 0xDB, 0xF4, 0x8E);
我把DARK_GREEN的RGB改寫成#DBF48E (0x表示16進位)
(你要什麼顏色而有什麼16進位色碼,很多方法可以取得,比如:Photoshop、Dreamweaver等)
這樣一來,之後再使用Colour.DARK_GREEN,就會變成我們想要的顏色了。
4. 產生儲存格Cell的格式
WritableCellFormat cellFormat1 = new WritableCellFormat ();
cellFormat1.setFont(chFont11w);
cellFormat1.setBackground(Colour.DARK_GREEN);
cellFormat1.setAlignment(Alignment.CENTRE);
cellFormat1.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.GRAY_80);
這裡呢,要先產生你要的cell的格式,例如指定字型setFont,把我們剛剛產生的白色11大小的TIMES指定進去,
設定背景setBackground,把我們剛剛覆寫掉的DARK_GREEN指定進去,
指定對齊方式setAlignment為置中,
以及設定此cell的上下左右(Border.ALL)的框線以及顏色。
5. 增加一個文字儲存格Cell
Label label = new Label(2, 3, "我是rexmen", cellFormat1);
sheet.addCell(label);
此constructor的第一個參數是產生的儲存格的x的位置,2表示第3欄(index從0開始算)
第二個參數就是y的位置,3表示第4列。
用Excel的講法來說,就是「C4」那一格。
而第三個就是輸入的文字,而第四格就把我們剛剛產生的cell的format指定進去。
最後再把此label加入sheet中。使用addCell method。
6. 寫入及結束文件
把該作的都作完後,別忘了close掉文件,
workbook.write();
workbook.close();
先使用write()寫入後,再用colose關閉。
這樣就大功告成囉!最基本的JExcel就完成了。
其他的功能啦,插入圖片啦、試算的公式啦、有的沒的自己有空再試了!
其他:
若是在JSP上要讓User download這個動態產生的excel檔,
要用Servlet RequestDispatcher的方式,
若沒有設定正確表頭,導過去的檔案會會在browser上看到的是亂碥,
要記得設定 response.setContentType("application/vnd.ms-excel");
再導到正確的excel檔案位置
RequestDispatcher view = request.getRequestDispatcher("test.xls");
view.forward(request, response);
如此以來,在網址列上不會show出 test.xls 的檔名 (會按照你在web.xml裡設定的servlet對應mapping檔名),
而且可以正確的在browser裡看到Excel的內容。
分享到:
相关推荐
JExcel API(简称JXL)是一个流行的开源库,允许开发者使用Java动态创建、读取和修改Excel文件。以下是对如何使用JExcel API创建Excel文件的详细步骤和相关知识点的介绍。 首先,你需要从JExcel API的官方站点或者...
JXL库是一个广泛使用的Java库,它允许开发者读取、写入和修改Excel文件。本篇将深入探讨如何使用JXL库在Java中打印Excel报表。 首先,要使用JXL库,你需要在项目中引入它的依赖。在本例中,`jxl.jar`是JXL库的核心...
jxl库是一个广泛使用的开源库,它允许开发者用Java读取、写入和修改Excel文件。本篇文章将深入探讨如何使用jxl库来实现数据从数据库导出到Excel的过程。 首先,要使用jxl库,你需要将其添加到项目的类路径中。如果...
### Java Jxl (导入导出Excel):详细知识点解析 #### 概述 Jxl 是一款用于处理 Excel 文件的 Java 库,支持多种版本的 Excel 文件格式,包括 Excel 95 至 2000 版本。该库允许开发者以纯 Java 的方式创建、读取和...
`jxl`库是一个广泛使用的第三方库,它允许开发者轻松地读取、写入和修改Excel文件。本篇文章将深入探讨如何利用`jxl.jar`包来实现这一功能。 首先,确保你已经正确地将`jxl.jar`文件添加到你的项目类路径中。这可以...
本篇文章将深入探讨如何使用jxl.jar库来实现Java操作Excel。 首先,jxl是一个广泛使用的Java库,它允许开发者读写Microsoft Excel文件。它的主要优势在于简单易用且功能丰富,支持多种Excel格式,包括老版本的.BIFF...
java 线程池jxl动态写入Excel
通过以上步骤,我们可以实现在Java程序中使用JXL和POI库给Excel文件添加动态水印的功能。这种技术不仅适用于企业内部的文档管理,还可以用于任何需要保护文档版权和安全性的场景。希望这篇教程能够帮助到有类似需求...
Java 使用 JXL 进行Excel导入导出是一个常见的任务,特别是在数据处理和分析场景中。JXL 是一个 Java 库,允许开发者方便地读取、写入和操作 Excel 文件(.xls 格式)。以下是对这个主题的详细阐述: 1. **JXL 概述...
Java使用JXL库生成Excel文件是一项常见的任务,特别是在数据处理、报表生成或导出时。JXL是一个开源的Java库,允许我们读取、写入和修改Excel文件。以下将详细讲解如何使用JXL库来生成Excel文件。 首先,我们需要在...
Java使用JXL库进行Excel操作是Java开发中常见的任务,特别是在数据处理、报表生成和数据分析等领域。JXL是一个流行的开源库,它提供了丰富的API来读取、写入和修改Microsoft Excel文件。以下是对这个主题的详细说明...
【Java Jxl库详解:轻松实现Excel导入导出】 Java Jxl库是一个强大的工具,用于在Java应用程序中处理Microsoft Excel文件。它支持从Excel 95到2000的所有版本,同时也允许生成Excel 2000标准格式的文件。Jxl的主要...
标题中的“用jxl实现java对Excel表格的增删改查”指的是使用JXL库来完成对Excel文件的基本操作:增加数据(Add)、删除数据(Delete)、修改数据(Modify)以及查询数据(Query)。以下是对这些操作的详细说明: 1....
本篇文章将深入探讨如何使用JXL包在Java中创建和导出Excel表格。 首先,我们需要了解JXL库的基本概念。JXL库提供了API,使得Java程序可以与Excel文件进行交互,包括创建新的工作簿、添加工作表、设置单元格格式、...
首先,让我们关注`jxl.jar`库,它是一个广泛使用的Java库,允许开发者读取、写入和修改Excel文件。以下是如何使用jxl.jar来读取和写入Excel文件的基本步骤: 1. **读取Excel文件**: - 引入jxl.jar库到项目类路径...
JXL库是一个广泛使用的开源库,它允许开发者在Java应用程序中方便地读取和写入Excel文件。本篇将详细介绍如何使用JXL进行Excel的读写操作,并提供一个在MyEclipse环境中可以直接运行的示例代码。 首先,你需要在...
Java中的JXL库是一个流行的API,它允许开发者方便地读取、写入...通过研究这些实例,你将能熟练掌握Java中使用JXL库进行Excel文件操作的技巧,无论是简单的数据读写,还是复杂的格式设置和公式计算,都将变得易如反掌。
Java Jxl库是一个专门用于处理Excel文件的开源Java库,它允许开发者在Java应用程序中进行Excel文件的读取、创建和修改。Jxl支持多种Excel版本,包括从Excel 95到2000,而且生成的文件格式符合Excel 2000的标准。这个...
Java使用JXL库进行Excel导入导出是一种常见的技术实践,特别是在需要在Java应用程序或Web应用中处理Excel数据时。JXL是一个轻量级的库,它允许开发人员以纯Java方式读取、创建和修改Excel文件,而无需依赖于Windows...