注:本文代碼在第一篇文章基礎上修改而成,請務必先閱讀第一篇文章。html
http://www.cnblogs.com/foxlee1024/p/7616987.htmljava
本文也不會過多的講解模板中遍歷表達式的寫法和說明,請先閱讀第二篇文章。工具
http://www.cnblogs.com/foxlee1024/p/7617120.htmlthis
本來第三篇文章我打算寫sheet分頁的實現的,後來發現難度比第四篇循環嵌套複雜一點點,咱們本着按部就班的原則,因此先講講怎麼實現循環嵌套。spa
說明是嵌套循環?說白了就是大循環套小循環,請看下圖:翻譯
咱們設想一下,有一條哆啦A夢的流水生產線,生產線上在生成這哆啦A夢。咱們知道,哆啦A夢的口袋中有不少不一樣的道具,那麼咱們在生成的時候就把這些道具預先放進哆啦A夢的口袋吧。設計
每個產品的哆啦A夢擁有的道具都是不同的,這樣咱們在表中就須要到了兩個循環,第一層是哆啦A夢名稱和擁有的道具,第二層循環是擁有的道具名稱和道具功能。excel
Main方法中導出的代碼和原來沒什麼不一樣,因此咱們先看看哆啦A夢的javabean是怎麼設計的。code
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類:htm
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方法中執行代碼了。