导出数据到Excel--多sheet
import java.io.*; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.util.*; import java.util.regex.Matcher; import java.util.regex.Pattern; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.alibaba.druid.support.json.JSONUtils; import jxl.Workbook; import jxl.format.Alignment; import jxl.format.Colour; import jxl.format.UnderlineStyle; import jxl.write.*; import org.aspectj.util.FileUtil; /** * 封装数据 * @param i * @param strTitle * @param object * @param category * @return */ public static Map getMapType(int i, Object strTitle, Object object, String category) { try { Map map = new HashMap(); String str = ""; if (strTitle != null) { str=strTitle.toString(); } map.put("code",(char)((int)'A'+i)); map.put("title",str); map.put("category",category); if(object!=null){ map.put("value",object.toString()); }else { map.put("value",""); } return map; } catch (Exception e) { e.printStackTrace(); } return null; } /** * 导出数据到Excel--多sheet * @param file * @param mapData * @param page * @param fileName */ public static void downLoadFile(String file,List<List<Map>> mapData,int page,String fileName){ //大标题 WritableFont wf_title=new WritableFont(WritableFont.ARIAL,20,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.BLACK); WritableCellFormat wcf_table=new WritableCellFormat(wf_title); try{ wcf_table.setAlignment(Alignment.CENTRE); }catch (WriteException e){ e.printStackTrace(); } //小标题 WritableFont wf_title1=new WritableFont(WritableFont.ARIAL,13,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,Colour.BLACK); WritableCellFormat wcf_table1=new WritableCellFormat(wf_title1); try{ wcf_table1.setAlignment(Alignment.LEFT); }catch (WriteException e){ e.printStackTrace(); } WritableWorkbook wwb=null; Workbook wb=null; if(page!=0){ try{ wb=Workbook.getWorkbook(new File(file)); wwb=Workbook.createWorkbook(new File(file),wb); WritableSheet sheet=wwb.createSheet(fileName,page); Label label=null; int maxSize=0; int num=0; for(int i=0;i<mapData.size();i++){ if(mapData.get(i).size()>maxSize){ maxSize=mapData.get(i).size(); num=i; } } int maxCol=0; int minCol=0; for(int z=0;z<mapData.get(num).size();z++){ label=new Label(z,1,mapData.get(num).get(z).get("title").toString(),wcf_table1); sheet.addCell(label); sheet.setColumnView(z,20); if("经济责任类".equals(mapData.get(num).get(z).get("category").toString())){ minCol++; }else { maxCol++; } } label =new Label(0,0,mapData.get(num).get(0).get("category").toString(),wcf_table); sheet.addCell(label); sheet.mergeCells(0,0,maxCol -1 ,0); if(minCol!=0){ label=new Label(maxCol,0,mapData.get(num).get(maxCol).get("category").toString(),wcf_table); sheet.addCell(label); sheet.mergeCells(maxCol,0,minCol-1+maxCol,0); } for(int i=0;i<mapData.size();i++){ List<Map> data=mapData.get(i); for(int j=0;j<data.size();j++){ label=new Label(j,i+2,data.get(j).get("value").toString()); sheet.addCell(label); } } wwb.write(); }catch(Exception e){ e.printStackTrace(); }finally { if(wwb!=null){ try{ wwb.close(); }catch (IOException e){ e.printStackTrace(); }catch (WriteException e){ e.printStackTrace(); } } if(wb!=null){ try{ wb.close(); }catch (Exception e){ e.printStackTrace(); } } } }else{ OutputStream os=null; try{ os=new FileOutputStream(file); wwb=Workbook.createWorkbook(os); WritableSheet sheet=wwb.createSheet(fileName,page); Label label=null; int maxSize=0; int num=0; for(int i=0;i<mapData.size();i++){ if(mapData.get(i).size()>maxSize){ maxSize=mapData.get(i).size(); num=i; } } int maxCol=0; int minCol=0; for(int z=0;z<mapData.get(num).size();z++){ label=new Label(z,1,mapData.get(num).get(z).get("title").toString(),wcf_table1); sheet.addCell(label); sheet.setColumnView(z,20); if("经济责任类".equals(mapData.get(num).get(z).get("category").toString())){ minCol++; }else { maxCol++; } } label =new Label(0,0,mapData.get(num).get(0).get("category").toString(),wcf_table); sheet.addCell(label); sheet.mergeCells(0,0,maxCol -1 ,0); if(minCol!=0){ label=new Label(maxCol,0,mapData.get(num).get(maxCol).get("category").toString(),wcf_table); sheet.addCell(label); sheet.mergeCells(maxCol,0,minCol-1+maxCol,0); } for(int i=0;i<mapData.size();i++){ List<Map> data=mapData.get(i); for(int j=0;j<data.size();j++){ label=new Label(j,i+2,data.get(j).get("value").toString()); sheet.addCell(label); } } wwb.write(); }catch(Exception e){ e.printStackTrace(); }finally { if(wwb!=null){ try{ wwb.close(); }catch (IOException e){ e.printStackTrace(); }catch (WriteException e){ e.printStackTrace(); } } if(wb!=null){ try{ wb.close(); }catch (Exception e){ e.printStackTrace(); } } } } }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
2017-08-31 设计模式(12)--Proxy(代理模式)--结构型