JXLS 2.4.0系列教程(三)——嵌套循環是怎么做到的


注:本文代碼在第一篇文章基礎上修改而成,請務必先閱讀第一篇文章。

http://www.cnblogs.com/foxlee1024/p/7616987.html

本文也不會過多的講解模板中遍歷表達式的寫法和說明,請先閱讀第二篇文章。

http://www.cnblogs.com/foxlee1024/p/7617120.html

 

  原本第三篇文章我打算寫sheet分頁的實現的,后來發現難度比第四篇循環嵌套復雜一點點,我們本着循序漸進的原則,所以先講講怎么實現循環嵌套。

說明是嵌套循環?說白了就是大循環套小循環,請看下圖:

 

 

  我們設想一下,有一條哆啦A夢的流水生產線,生產線上在生成這哆啦A夢。我們知道,哆啦A夢的口袋中有很多不同的道具,那么我們在生成的時候就把這些道具預先放進哆啦A夢的口袋吧。

  每一個產品的哆啦A夢擁有的道具都是不一樣的,這樣我們在表中就需要到了兩個循環,第一層是哆啦A夢名稱和擁有的道具,第二層循環是擁有的道具名稱和道具功能。

  Main方法中導出的代碼和原來沒什么不同,所以我們先看看哆啦A夢的javabean是怎么設計的。

public class Doraemon {
    private String name; // 哆啦A夢的名字
    private List<Tool> tools; // 擁有的道具,這是一個鏈表,存放的是Tool類
    
    public Doraemon(String name, List<Tool> tools) {
        super();
        this.name = name;
        this.tools = tools;
    }
    
    public Doraemon() {
    }
    
    /** 以下省略所有get/set方法,請自行添加 */
}

 

  接下來我們看看Tool類:

public class Tool {
    private String toolName; // 道具名
    private String toolFunction; // 道具功能
    
    public Tool(String toolName, String toolFunction) {
        super();
        this.toolName = toolName;
        this.toolFunction = toolFunction;
    }
    
    public Tool() {
    }
    
    /** 以下省略所有get/set方法,請自行添加 */
}

 

  現在大家看明白了嗎?其實就是在Doraemon 類中加入了一個List鏈表,泛型為Tool。可以預想的是,只要一層層創建好哆啦A夢這個對象(包括他的道具)后,再把多個多啦A夢放進一個鏈表中,然后傳給Jxls工具就可以生成excel報表了。

  現在我們看看Main方法是怎么寫的,除了生成哆啦A夢對象的代碼外,其他完全沒有改動。

public class TestMain2 {

    public static void main(String[] args) throws Exception {
        String templatePath = "E:/template6.xls";
        OutputStream os = new FileOutputStream("E:/out6.xls");
        
        Tool tool1 = new Tool("任意門","想去哪就去哪");
        Tool tool2 = new Tool("竹蜻蜓","想飛哪就飛哪");
        Tool tool3 = new Tool("空氣炮","空氣炮");
        Tool tool4 = new Tool("翻譯餅干","翻譯餅干");
        
        List<Doraemon> list = new ArrayList<Doraemon>();
        
        //制作一個哆啦A夢
        Doraemon doraemon1 = new Doraemon();
        //制作一號哆啦A夢的道具
        List<Tool> toolList1 = new ArrayList<Tool>();
        toolList1.add(tool1);
        toolList1.add(tool2);
        //設定一號哆啦A夢信息
        doraemon1.setName("哆啦A夢一號");
        doraemon1.setTools(toolList1);
        
        //制作一個哆啦A夢
        Doraemon doraemon2 = new Doraemon();
        //制作二號哆啦A夢的道具
        List<Tool> toolList2 = new ArrayList<Tool>();
        toolList2.add(tool3);
        toolList2.add(tool4);
        toolList2.add(tool1);
        //設定二號哆啦A夢信息
        doraemon2.setName("哆啦A夢二號");
        doraemon2.setTools(toolList2);
        
        list.add(doraemon1);
        list.add(doraemon2);
        
        Map<String, Object> model = new HashMap<String, Object>();
        model.put("data", list);    
        
        JxlsUtils.exportExcel(templatePath, os, model);
        os.close();
        System.out.println("完成");
    }
}

 

  Main方法不多解釋,就是new出一個新的哆啦A夢后給他set入對應的數據(包括名字和擁有的道具),然后把一眾哆啦A夢放進一個鏈表中,再傳進model中。

  重點是我們看看模板應該怎么寫。

 

 

  第一句不用多說,設定模板區域(我隨便寫的,可以寫大一點):

jx:area(lastCell="I7")

  第二句是第一層循環,items是Main方法中model放入的鍵名,里面存放有裝着生產線所有哆啦A夢對象的一個鏈表。他的var值是dora,在獲取產品名稱時就要寫成${dora.name}。lastCell的值寫C4,D4都行。

jx:each(items="data" var="dora" lastCell="D4")

  第三句是第二層循環,是哆啦A夢對象(Doraemon)里的tools屬性,是個鏈表。由於上一層循環中Doraemon對象已經在var值中被命名成dora,所以第二層循環的items寫成dora.tools。並且var值為tool。這就意味着Doraemon對象tools屬性中的單條遍歷記錄被命名成tool。所以就可以在表達式中用${tool.toolName}方法獲取道具的名字(toolName)了。

jx:each(items="dora.tools" var="tool" lastCell="D4")

  不明白的同學請仔細品味一下,items相當於一個鏈表List,而var相當於鏈表中存放的單個對象。要使用這些對象就要給他們在var中命名。

  寫好這三句注解后,就可以回到main方法中執行代碼了。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM