5.JXL操作Excel

来源:https://www.cnblogs.com/lukelook/archive/2018/03/27/8661075.html
-Advertisement-
Play Games

一.簡介 jxl是一個南韓人寫的java操作excel的工具, 在開源世界中,有兩套比較有影響的API可 供使用,一個是POI,一個是jExcelAPI。其中功能相對POI比較弱一點。但jExcelAPI對中文支持非常好,API是純Java的, 並不 依賴Windows系統,即使運行在Linux下, ...


一.簡介

jxl是一個南韓人寫的java操作excel的工具, 在開源世界中,有兩套比較有影響的API可 供使用,一個是POI,一個是jExcelAPI。其中功能相對POI比較弱一點。但jExcelAPI對中文支持非常好,API是純Java的, 並不 依賴Windows系統,即使運行在Linux下,它同樣能夠正確的處理Excel文件。 另外需要說明的是,這套API對圖形和圖表的支持很有限,而且 僅僅識別PNG格式。

二.簡單的實現代碼

 Maven 依賴

<dependency>
<groupId>net.sourceforge.jexcelapi</groupId>
<artifactId>jxl</artifactId>
<version>2.6.12</version>
</dependency>

 

package com.my.utils;

import java.io.File;

import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

public class UseJxlCreateExcel {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        try {
            WritableWorkbook book = Workbook.createWorkbook(new File("D:\\java\\test\\jxlTest.xls"));
            WritableSheet sheet = book.createSheet(" 第一頁 ", 0);
            Label label1 = new Label(0, 0, "姓名");
            Label label2 = new Label(1, 0, "年齡");
            sheet.addCell(label1);
            sheet.addCell(label2);
            book.write();
            book.close();

            Workbook workbook = Workbook.getWorkbook(new File("D:\\java\\test\\jxlTest.xls"));
            Sheet worksheet = workbook.getSheet(0);
            Cell cell1 = worksheet.getCell(0, 0);
            String result = cell1.getContents();
            System.out.println(result);
            workbook.close();

        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

}

 

詳見:http://www.cnblogs.com/raymond19840709/archive/2008/06/26/1230289.html

三.poi和 jxl

目前我所負責的系統中有POI和JXL兩種方式的導出數據實現。 
項目初期數據量不大一般使用JXL的方式,可以滿足需求,後來在進行一些盤點,
等月度出入庫查詢報表統計的時候出現了超過最大sheet行的錯誤,另外堆記憶體也被占滿了。 所以後面就緊急將部分重要功能,要導的數據量大的幾個模塊改造成POI的方式了。
但是仍然跑的很慢,沒有瞭解POI的另外一種實現方式,後來對POI的工具類,以及POI的導出實現做了部分修正,順利完成升級。

我的初步瞭解: 
JXL:支持比較低版本的excel,比如Excel 95 ,97 ,2000,2003 
由於Excel版本比較低,導致最大行有限制,無法導出65535以上量級的數據 
對於記憶體,和時間的花費也比POI基於記憶體+磁碟的方式高。

網友技術說明 
1. 讀取Excel公式(可以讀取Excel 97以後的公式) 
2. 生成Excel數據表(格式為Excel 97) 
3. 支持字體、數字、日期的格式化 
4. 支持單元格的陰影操作,以及顏色操作 
5. 修改已經存在的數據表 
6. 是最基礎的excel api 
7. 小文件讀取效率比較高 
8. 跨平臺 
POI技術說明

  1. 能保持Excel里原有的巨集(但不能用它寫新的巨集)。
  2. 不支持跨平臺(主要就是Java語言)
  3. 在一些業務場景中代碼相對複雜,但是API豐富,支持多種模式的讀寫。
  4. 支持比較新版本的excel.
  5. 讀寫的時候比較占記憶體。
  6. 讀寫的時候比較占記憶體。
  7. 支持大數量大文件的讀寫操作。但是需要熟悉API。

總體來說,對於簡單的單表excel導入導出的需求,建議使用JXL。數據量稍微小點,占用記憶體少,速度快。 
對於報表類的,涉及月份數據量,多表數據聚合在一起建議使用POI。

從優缺點上來說

一、jxl

優點:

Jxl對中文支持非常好,操作簡單,方法看名知意。
Jxl是純javaAPI,在跨平臺上表現的非常完美,代碼可以再windows或者Linux上運行而無需重新編寫
支持Excel 95-2000的所有版本(網上說目前可以支持Excel2007了,還沒有嘗試過)
生成Excel 2000標準格式
支持字體、數字、日期操作
能夠修飾單元格屬性
支持圖像和圖表,但是這套API對圖形和圖表的支持很有限,而且僅僅識別PNG格式。

缺點:效率低,圖片支持不完善,對格式的支持不如POI強大

二、POI

優點:

效率高(數據來源:http://blog.csdn.net/jarvis_java/article/details/4924099)
支持公式,巨集,一些企業應用上會非常實用
能夠修飾單元格屬性
支持字體、數字、日期操作

缺點:不成熟,代碼不能跨平臺,貌似不少同行在使用工程中還碰到讓人鬱悶的BUG(最近的項目中也是遇到了一些bug,不過目前沒有查出來是代碼的問題還是POI的問題,總之問題很詭異,數據替代參數總有失敗的。關於不能跨平臺這一說,我也沒有試驗過,不過Java不是跨平臺嗎?POI是JAVA的一個組件,怎麼就不能跨平臺了呢,總之這些問題還需要在以後的項目中多多實踐,才能比較出區別之處。)

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 外觀模式應該是程式員最下意識用的一種模式,比如我們習慣性的對複雜系統做一個封裝介面。外觀模式其本質是對一堆複雜對象和應用的介面抽象,對它們進行封裝隔離,對於調用者來說只需要關係介面的實現,而不需要知道內部有哪些對象和調用。 作用 為模塊的一組介面提供一致的界面,定義了一個高層介面,這個介面使得這一模 ...
  • 針對消息隊列的數據積壓問題,我們主要做了三個方面的優化處理,取消同步鎖、ActiveMQ參數優化、本地雙隊列優化,通過這三個方面的優化基本解決了隊列數據積壓的問題。 ...
  • 月薪30K java程式員2018年java學習進階書籍推薦 ...
  • 內容:例子 ...
  • Hibernate框架 一、什麼是hibernate? Hibernate是一個開放源代碼的對象關係映射框架,它對JDBC進行了非常輕量級的對象封裝,它將POJO與資料庫表建立映射關係,是一個全自動的orm框架,hibernate可以自動生成SQL語句,自動執行,使得Java程式員可以隨心所欲的使用 ...
  • 2018-03-28 00:56:39 中斷正在執行的代碼 無論是%run執行的腳本還是長時間運行的命令ctrl + cIn [1]: KeyboardInterrupt 執行剪切板中的代碼 ctrl-shift-V %paste,%cpaste魔術函數%paste可以承載剪切板中的一切文本,併在s ...
  • 根據一個知乎高票回答的THU大神學習的 http://nbviewer.jupyter.org/github/lijin THU/notes python/tree/master/ 只整理了一些我認為不太熟悉的東西 對於acmer或者一些熟悉C++的童鞋來說應該有些參考吧,我覺得 我覺得python ...
  • 最近一直陷入一個誤區,老是找一些網上關於SSM速成等視頻學習,然後盲目的跟著'複製'代碼,當時跟著視頻敲完代碼,實現了某些功能後,感覺自己對Spring等一些框架已經有了足夠的瞭解(其實只是知其然,不知其所以然。) 過了一段時間,工作中用不到Spring,等到某天需要使用的時候,突然發現連手動搭建一 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...