精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Java 導出 Excel 利器:JXLS

開發 開發工具
簡單的excel格式,用簡單的poi,easyExcel等工具都能導出。但是針對復雜的excel,有固定的樣式、合并單元格、動態列等各類要求,導致excel 導出需要花很大一部分精力去寫代碼。jxls在很大程度上解決了以上問題。

jxls是一個輕量級的Java庫,用于基于模板的Excel報表生成。

jxls作為一個開源工具,提供了一種高效且易于維護的方式來處理復雜的Excel導出需求。它允許用戶通過在Excel模板中放置特定的標記或注釋來定義數據的輸出格式和布局,從而避免了編寫大量重復且易出錯的代碼。

標注:簡單的excel格式,用簡單的poi,easyExcel等工具都能導出。但是針對復雜的excel,有固定的樣式、合并單元格、動態列等各類要求,導致excel 導出需要花很大一部分精力去寫代碼。jxls在很大程度上解決了以上問題。

以下是jxls的一些主要特點:

  • 簡單性: jxls的設計哲學是簡單和直觀,使得即使是初學者也能快速上手并使用它來創建復雜的Excel報表。
  • 靈活性: 通過在Excel模板中使用類似jsp的標簽,jXls提供了極高的靈活性,可以輕松地生成各種格式的報表。
  • 輕量級: 與其他Java Excel庫相比,jxls更加輕量,不會給項目增加太多的負擔。
  • 功能強大: jxls特別適合于處理包含固定樣式、合并單元格和動態列等復雜要求的Excel導出任務。
  • 易于維護: 使用jxls可以減少因手動編碼導致的維護成本和出錯概率,提高項目的可維護性。

添加jar

很高興在編寫文章時發現jxls的大版本升級了,所使用的jdk版本也來到了17。

對于原先的jxls2.x版本的使用者來說,新的構建器 API 取代了 JxlsHelperTransformerFactory 和 createTransformer() 方法也已被刪除。

Context 現在包含創建報表所需的所有信息。但數據以Map<String, Object> 的形式傳遞給 JxlsTemplateFiller

<dependency>
    <groupId>org.jxls</groupId>
    <artifactId>jxls-poi</artifactId>
    <version>3.0.0</version>
</dependency>

XlsArea 區域

Area是jXLS中的一個主要概念,它本質上代表了一個矩形區域,這個區域包含了需要進行數據轉換的單元格。每個Area可以包含一組轉換命令和一組嵌套的子區域,這些子區域也是Area,它們有自己的命令和子區域。

如下命令表示需要處理的區域為從A1至K列第4行:

jx:area(lastCell="K4")

創建報表

因為大版本的升級,我們不再使用如下方式:

Context context = new Context();
context.putVar("list", list);
JxlsHelper.getInstance().setEvaluateFormulas(evaluateFormulas).processTemplate(inputStream, outPutStream, context);

而是:

Map<String, Object> data = new HashMap<>();
data.put("employees", employees);
JxlsPoiTemplateFillerBuilder.newInstance()
        .withTemplate("template.xlsx")
        .build()
        .fill(data, new File("report.xlsx"));

循環

循環是用的最多的標簽,用于循環輸出各列數據:

jx:each(items="weeks" var="week"  lastCell="B4")

示例:

publicclassEmployee{
    private String name;
    private Date birthDate;
    private BigDecimal payment;
    private BigDecimal bonus;
    // getters/setters ...
    publicEmployee(String name, Date birthDate, double payment, double bonus){
        this(name, birthDate, new BigDecimal(payment), new BigDecimal(bonus));
    }
     public String getSalaryGroup(){
        return payment.doubleValue() > 2000d ? "high" : "normal";
    }
}

 List<Employee> employees = new ArrayList<>();
 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MMM-dd", Locale.US);
 employees.add(new Employee("Elsa", dateFormat.parse("1970-Jul-10"), 1500, 0.15));
 employees.add(new Employee("Oleg", dateFormat.parse("1973-Apr-30"), 2300, 0.25));
 employees.add(new Employee("John", dateFormat.parse("1970-Jul-10"), 3500, 0.10));
 employees.add(new Employee("Neil", dateFormat.parse("1975-Oct-05"), 2500, 0.00));
 employees.add(new Employee("Maria", dateFormat.parse("1978-Jan-07"), 1700, 0.15));
 employees.add(new Employee("John", dateFormat.parse("1969-May-30"), 2800, 0.20));
 employees.add(new Employee("Oleg", dateFormat.parse("1988-Apr-30"), 1500, 0.15));
 employees.add(new Employee("Maria", dateFormat.parse("1970-Jul-10"), 3000, 0.10));
 employees.add(new Employee("John", dateFormat.parse("1973-Apr-30"), 1000, 0.05));
return employees;

將模版編輯為如下:

圖片圖片

根據輸出報表查看結果。

1.multisheet 多sheet頁
jx:each(items="employees" var="e" multisheet="sheetNames" lastCell="B4")

圖片圖片

輸出:

圖片圖片

2.方向向右

默認值為 directinotallow=“DOWN”,將創建行。將使用 directinotallow=“RIGHT” 創建列。

您也可以為特殊情況設置自己的 cellRefGenerator,但在此不再進一步描述。

jx:each(items="e.departments" var="d" lastCell="D2" directinotallow="RIGHT")
3.索引

有時我們需要顯示循環的索引。使用屬性 varIndex 指定將保存從 0 開始的迭代索引的變量名稱。

jx:each(items="employees" var="e" varIndex="index" lastCell="C2")

顯示:

圖片圖片

4.過濾

只有選擇條件為 true 的項才會成為輸出的一部分。

jx:each(items="employees" var="e" select="e.payment > 2000" lastCell="C2")

圖片圖片

圖片圖片

5. 分組和分組排序

在屬性中指定 var name + “.” + 屬性名稱以對項目進行分組。還必須在屬性中指定 ASC、DESC此時將在組內部進行排序。

比如employee類中有salaryGroup(工資)方法來指定該人是否大于2000元。

示例代碼:

jx:each(items="employees" var="g" groupBy="g.salaryGroup" groupOrder="ASC" lastCell="C3")

示例圖:

圖片圖片

圖片圖片

判斷

jx:if 命令根據條件表達式顯示/隱藏單元格。這就像 Java 中的 if 或 if,else

jx:if(cnotallow="e.payment<2000" lastCell="C2" areas=["A2:C2","A3:C3"])

condition:如果表達式結果為真,則顯示區域,否則隱藏區域; 如果表達式結果不為 true,則顯示其他區域,否則隱藏其他區域。

圖片圖片

圖片圖片

動態行列

jx:grid 命令可用于生成具有標題區域和數據行區域的動態網格。

jx:grid(headers="headers" data="items" areas=["A3:A3","A4:A4"] formatCells="BigDecimal:C1,Date:D1" lastCell="A4")

圖片圖片

圖片圖片

合并單元格

jx:mergeCells(cols="" rows="" minCols="" minRows="" lastCell="C2")
  • cols: 組合列數
  • rows: 合并的行數
  • minCols: 要合并的最小列數
  • minRows: 要合并的最小行數
  • lastCell: 合并單元格范圍。

圖片

使用此命令將圖像添加到工作表中。

jx:image(src="image" lastCell="A2")
  • src: 返回包含圖像數據的 byte[] 數組的表達式
  • imageType: 可以包含以下值:PNG(默認值)、JPEG(非 JPG)、EMFWMFPICTDIB
  • scaleX和scaleY: 縮放參數(可選)
  • lastCell: 區域結束

excel 公式處理

參數化公式允許在公式中使用變量,必須將其括在$[ ] 符號中,比如我們需要把數據輸出的同時進行計算,比如我們數據中的比率值是1(excel上最終需要顯示為1%)。我們可以修改代碼為$[${item.taxRate}/100],其中${item.taxRate}表示我們自己的迭代變量,同時改變單元格樣式為百分比,此時輸出的值才會是1%

JXLS官網:https://jxls.sourceforge.net/

責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2021-03-11 08:24:48

Javapoi數據脫敏

2025-05-06 01:00:00

Excel高性能內存

2020-12-02 11:56:16

Java注解Excel

2025-11-05 08:23:56

2023-02-25 10:04:21

JavaExcel導出功能

2023-02-03 08:21:30

excelMySQL

2025-05-12 00:00:00

2020-09-22 09:41:09

前端

2012-04-28 10:50:51

jQuery

2024-09-12 17:23:02

2021-03-26 07:09:15

Java技術pdfExcel

2025-02-12 07:27:52

MySQL8分頁查詢excel

2022-09-21 08:16:18

緩存框架

2025-06-16 07:07:03

Java數據Jackson

2009-12-04 16:49:38

PHP導出Excel亂

2022-12-29 08:49:40

SpringBootExcel

2010-07-21 14:17:36

SQL Server數

2009-06-16 14:09:00

Netbeans介紹

2022-05-12 08:32:25

JavaArthas阿爾薩斯

2015-08-21 09:56:17

Java內存分析MAT使用
點贊
收藏

51CTO技術棧公眾號

国产亚洲一区二区手机在线观看| 精品人妻一区二区三区含羞草| 最近国产精品视频| 欧美午夜精品一区二区三区| 性欧美18一19内谢| 特黄视频在线观看| 久久激情综合网| 久久久久久久久久久av| 精品熟妇无码av免费久久| 亚洲欧洲国产精品一区| 日本精品免费观看高清观看| 青青在线视频免费观看| 东凛在线观看| 成人黄色大片在线观看| 91精品国产自产在线老师啪| 亚洲男人第一av| 欧美在线首页| 自拍偷拍亚洲在线| 捆绑凌虐一区二区三区| 依依综合在线| 亚洲一区二区三区四区在线观看| 涩涩涩999| 色哟哟国产精品色哟哟| 国产一区欧美日韩| 国产精品成人aaaaa网站| 日韩激情在线播放| 中文不卡在线| 日韩在线视频免费观看| 波多野结衣 在线| 美女一区2区| 日韩欧美国产不卡| 超碰在线资源站| 成人国产激情在线| 色婷婷激情综合| 男人操女人逼免费视频| 精品精品导航| 一区二区久久久久| 91看片淫黄大片91| 二区在线播放| 亚洲特黄一级片| 波多野结衣激情| 男人影院在线观看| 国产精品情趣视频| 午夜精品视频在线观看一区二区| 日韩欧美亚洲系列| 91女人视频在线观看| 麻豆亚洲一区| 理论视频在线| 久久久久国产精品麻豆| 欧美日韩在线播放一区二区| 久久久久国产精品嫩草影院| 久久蜜桃av一区二区天堂| 精品国产一区二区三区免费| 国产成人无码www免费视频播放| 国产自产2019最新不卡| 成人高清视频观看www| 97精品人妻一区二区三区香蕉| 免费人成精品欧美精品 | 久久成人资源| 天堂av电影在线观看| 久久久久久久电影| 亚洲国产高清国产精品| 欧美日韩在线看片| 亚洲人成精品久久久久| 97中文字幕在线| 国模雨婷捆绑高清在线| 午夜av一区二区| 亚洲爆乳无码专区| 六九午夜精品视频| 欧美一二三区在线| 岛国精品资源网站| 国产精品免费大片| 日韩在线观看av| 欧美精品一区二区成人| 亚洲全部视频| 国产精品第2页| 国产精品高潮呻吟AV无码| 国产精品一区在线观看你懂的| 91精品国产高清久久久久久91裸体 | 五月婷婷综合网| 男人透女人免费视频| 日韩一级特黄| 精品国产乱码久久久久久牛牛 | 色婷婷av一区二区三区久久| 一级性生活免费视频| 激情av一区| 国产成人精品综合久久久| 国产精选久久久| gogo大胆日本视频一区| 午夜视频久久久| 午夜在线激情影院| 色婷婷久久99综合精品jk白丝| 免费av不卡在线| 日韩欧美黄色| 久久精品国产成人精品| 中文字幕亚洲高清| 精品一区二区在线播放| 精品久久蜜桃| 国产原厂视频在线观看| 精品日韩中文字幕| 韩国一区二区在线播放| 伊甸园亚洲一区| 欧美成aaa人片免费看| 一级做a爰片久久毛片| 国产激情一区二区三区四区| 日韩免费三级| 123区在线| 欧美丰满嫩嫩电影| 娇妻被老王脔到高潮失禁视频| 欧美色综合网| 国产一区欧美二区三区| 日韩大片b站免费观看直播| 亚洲精品欧美激情| 污污动漫在线观看| 噜噜噜天天躁狠狠躁夜夜精品| 北条麻妃一区二区三区中文字幕| 国产成人精品一区二三区| 国产精品亚洲第一区在线暖暖韩国| 青青影院一区二区三区四区| 国产理论电影在线| 欧美一区二区三区免费观看视频 | 手机在线电影一区| 欧美综合一区第一页| 精品人妻一区二区三区麻豆91| 国产欧美日韩久久| 欧美大成色www永久网站婷| 国产精久久久久久| 国内精品久久久久影院薰衣草| 久久综合色一本| 免费男女羞羞的视频网站在线观看 | www.在线成人| 国产91视频一区| 亚洲高清影院| 在线看国产精品| 无码视频在线观看| 久久久精品人体av艺术| 日本欧美黄色片| 国产精品乱战久久久| 欧美国产中文字幕| 亚洲第一页在线观看| 亚洲免费在线看| 日韩a一级欧美一级| 一本到12不卡视频在线dvd| 成人日韩在线电影| 黄在线免费看| 日韩一区二区三区视频在线 | 色丁香久综合在线久综合在线观看| 午夜男人的天堂| 亚洲精品九九| 久久riav| 二吊插入一穴一区二区| 一区二区三区四区在线观看视频| 波多野结衣大片| 国产午夜久久久久| 午夜久久久精品| 国产精品成久久久久| 亚洲一区国产精品| 激情图片在线观看高清国产| 亚洲大胆人体在线| 国产成人在线视频观看| 久久婷婷国产综合精品青草| 99视频在线免费| 欧美3p在线观看| 亚洲va久久久噜噜噜| 国内老司机av在线| 亚洲欧美另类自拍| 在线免费看av片| 一区二区三区四区乱视频| 日韩av手机在线播放| 丝瓜av网站精品一区二区| 亚洲电影一二三区| 精品国产一区二| 69av成年福利视频| 成年网站在线| 日韩精品在线一区二区| 色婷婷av国产精品| 国产精品第13页| 无码人妻丰满熟妇啪啪网站| 国产麻豆综合| 亚洲一区高清| 加勒比久久高清| 国产精品视频午夜| 麻豆蜜桃在线| 中文字幕不卡在线视频极品| 99精品国产99久久久久久97| 婷婷丁香久久五月婷婷| 极品尤物一区二区| 成人免费视频一区| 91人人澡人人爽人人精品| 欧美黄在线观看| 欧美中文娱乐网| 免费精品一区二区三区在线观看| 欧美一级免费视频| 国产原厂视频在线观看| 亚洲人成网站777色婷婷| 99视频免费看| 欧美性猛片aaaaaaa做受| 久久精品视频8| 中文字幕亚洲成人| 一本色道综合久久欧美日韩精品 | 欧美色中文字幕| 国产特黄大片aaaa毛片| 亚洲婷婷综合色高清在线| 大黑人交xxx极品hd| 国产高清精品在线| 日日干夜夜操s8| 久久精品女人| 国产精品www在线观看| 色综合色综合| 欧美不卡福利| 国产成人福利av| 亚洲tv在线观看| 激情欧美一区二区三区黑长吊| 97色在线视频观看| 污污网站在线看| 色多多国产成人永久免费网站| 天堂在线视频观看| 日韩一级片在线播放| 中文字幕乱码中文字幕| 欧美性精品220| 国产污片在线观看| 亚洲免费av高清| 美女av免费看| 国产日韩精品一区二区三区| 黄色国产在线观看| 懂色av中文一区二区三区| 日韩成人精品视频在线观看| 免费的国产精品| 男人天堂成人在线| 丝袜美腿亚洲一区| 日本成年人网址| 亚洲欧美日本日韩| 日本精品一区在线观看| 99精品福利视频| www.成年人视频| 狠狠色综合网| 国产女主播自拍| 欧美三区不卡| 水蜜桃色314在线观看| 国内精品久久久久久久影视蜜臀| 一二三在线视频| 欧美黄污视频| 欧美无砖专区免费| 亚洲精品韩国| 男女午夜激情视频| 老司机午夜精品视频在线观看| 成人综合视频在线| 美女黄网久久| 天天天干夜夜夜操| 琪琪一区二区三区| 日本一二区免费| 国产乱码精品1区2区3区| 中文在线字幕观看| 成人aa视频在线观看| 亚洲第一黄色网址| 久久久久一区二区三区四区| 国产123在线| 成人欧美一区二区三区白人| 精品自拍偷拍视频| 亚洲国产日韩一区二区| 69成人免费视频| 欧美影院午夜播放| 国产女人爽到高潮a毛片| 欧美成人女星排行榜| 网站黄在线观看| 亚洲色图欧美制服丝袜另类第一页| aaa在线观看| 超薄丝袜一区二区| 99色在线观看| 国产不卡av在线免费观看| 久久人体av| 国产成人成网站在线播放青青| 日韩影视高清在线观看| 亚洲巨乳在线观看| 黄色一区二区三区四区| 国产成人久久777777| 美美哒免费高清在线观看视频一区二区| www.se五月| 成人av手机在线观看| 一区二区黄色片| 亚洲人成影院在线观看| 国产特黄大片aaaa毛片| 欧美人体做爰大胆视频| 亚洲精品成av人片天堂无码 | 久久国产柳州莫菁门| 亚洲精品国产品国语在线app| 看片网址国产福利av中文字幕| 欧美三级一区二区| 蜜桃av鲁一鲁一鲁一鲁俄罗斯的| 亚洲丝袜av一区| 四虎影院观看视频在线观看 | 国产精品亚洲lv粉色| 亚洲精品97久久| 久久日韩视频| 日韩美女在线播放| 免费看日产一区二区三区 | 在线观看免费视频黄| 国产欧美精品国产国产专区| 久久婷婷综合国产| 欧美日韩五月天| 婷婷五月综合久久中文字幕| 日韩一区二区精品视频| www.成人爱| 国产精品v欧美精品v日韩精品 | 免费超爽大片黄| 蜜臀av在线播放一区二区三区| 精品久久久久一区二区| 一区免费观看视频| 午夜一区二区三区四区| 亚洲精品v欧美精品v日韩精品| 免费**毛片在线| 国产精品第一视频| 欧美激情99| 一卡二卡三卡视频| 国产最新精品免费| 人成免费在线视频| 日韩欧美国产黄色| 天堂av2024| 欧美日韩不卡合集视频| 台湾天天综合人成在线| 色播亚洲婷婷| 久久福利影视| 久久一区二区电影| 亚洲韩国一区二区三区| 精品国产一级片| 久久天堂电影网| 久久麻豆视频| 一区二区精品国产| 蜜臂av日日欢夜夜爽一区| 欧美熟妇一区二区| 欧美天天综合色影久久精品| 日韩在线视频观看免费| 欧美大学生性色视频| 日韩高清一区| av影院在线播放| 懂色av一区二区三区免费观看| 在线免费观看亚洲视频| 在线综合+亚洲+欧美中文字幕| 欧美成人三区| 91久久久久久久久久| 仙踪林久久久久久久999| 天堂在线中文在线| 亚洲特级片在线| 99久久精品无免国产免费| 麻豆国产va免费精品高清在线| 青草综合视频| 裸体裸乳免费看| 国产精品白丝jk白祙喷水网站| 国产精品成人免费观看| 欧美videofree性高清杂交| 黄色污污视频在线观看| 国产一区二区自拍| 国产精品久久久久9999高清| 中文字幕被公侵犯的漂亮人妻| 欧美制服丝袜第一页| 免费观看久久久久| 7777精品伊久久久大香线蕉语言| 欧美午夜a级限制福利片| 影音先锋资源av| 欧美日韩免费在线| jyzzz在线观看视频| 91人成网站www| 亚洲人成在线影院| 中文字幕xxx| 欧美日本一区二区三区四区 | 亚洲综合成人在线| 天天影院图片亚洲| 国产精品久久久久久久久久免费| 99精品全国免费观看视频软件| 久久久久无码精品| 精品电影在线观看| yiren22综合网成人| 亚洲a级在线观看| 亚洲一区二区三区免费在线观看| 亚洲v国产v欧美v久久久久久| 91超碰这里只有精品国产| gogo高清在线播放免费| 奇米视频888战线精品播放| 国产精品一区二区不卡| 成人免费视频毛片| 日韩在线观看免费高清| 久久精品论坛| 亚洲国产日韩欧美在线观看| 亚洲综合久久av| 国产一区电影| 国产经品一区二区| 日本在线不卡视频| 国产亚洲欧美精品久久久久久 | a视频在线观看免费| 久久久精彩视频| 韩国理伦片一区二区三区在线播放| av大片免费在线观看| 色婷婷综合久久久久中文字幕1| 国产极品模特精品一二| 欧美伦理片在线观看| 亚洲mv在线观看| 看女生喷水的网站在线观看| 欧美大香线蕉线伊人久久国产精品 | 久久亚洲精品中文字幕蜜潮电影| 男人网站在线观看|