java poi excel 导出实例

以springMVC为例:
1.controller:

/**
     * 导出
     * @param request
     * @param response
     */
    @RequestMapping("/exportDiscountRatioExcel")
    public void exportDiscountRatioExcel(HttpServletRequest request,HttpServletResponse response)
    {
        Map<String, Object> paramsMap = getPageParams(request);
        
        try {
            Workbook wb = manager.exportExcel(request, paramsMap);
            String excelName = java.net.URLEncoder.encode("价格监测-车型折扣对比", "UTF-8");
            response.setContentType("application/vnd.ms-excel;charset=utf-8");  
            response.setHeader("Content-Disposition", "attachment;filename="+excelName+".xls" );  
            ServletOutputStream out = response.getOutputStream();  
            wb.write(out);
            
            //先把EXCEL写到临时目录,用来获取文件大小,最后删除
            File f = new File(request.getSession().getServletContext().getRealPath("/") + "/demoExcel/demo.xls");
            if(!f.exists())
            {
                f.createNewFile();
            }
            BufferedOutputStream s = new BufferedOutputStream(new FileOutputStream(f));
            wb.write(s);
            
            //关闭流
            s.flush();
            s.close();
            out.flush();
            out.close();
            
            //记录导出日志,并删除临时文件
            paramsMap.put("exportSize", AppFrameworkUtil.getNum(f.length()/1024, 0));
            logManager.updateModuleLog(paramsMap);
            f.delete();
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

2.serviceImpl:

      /**
       * 导出
       */
    @Override
    public Workbook exportExcel(HttpServletRequest request,Map<String, Object> paramsMap) 
    {
        Workbook wb = null;
        String json = (String) request.getSession().getAttribute(Constant.getExportExcelDataKey);
        String languageType = (String) paramsMap.get("languageType");//导出语言
        if(!AppFrameworkUtil.isEmpty(json))
        {
            JSONObject obj = (JSONObject) JSONObject.parse(json);
            JSONArray gridObj = (JSONArray) obj.getJSONArray("grid");
            
            try {
                //读取模块路径
                String path = request.getSession().getServletContext().getRealPath("/"); 
                wb = new HSSFWorkbook(new FileInputStream(new File(path+"excelExample/discountRatio.xls")));
                //导图
                exportLineChartExcel(wb,wb.getSheet("DATA"),gridObj,languageType);
                //导表格
                exportOriginalData(wb,wb.getSheet("原数据"),gridObj,languageType,paramsMap);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return wb;
    }
    
    /**
     * 导出原始数据
     * @param wb
     * @param s
     * @param gridObj
     * @param paramsMap
     */
    public void exportOriginalData(Workbook wb,Sheet s,JSONArray gridObj,String languageType,Map<String, Object> paramsMap)
    {
        String[] titles = null;//标题数组
        if("EN".equals(languageType)) 
        {
            titles = new String[]{"Date","Code","Segment","Manufacture","Model","Engine Capacity","Transmission","Trim","Bodytype","Launch Date","Model Year","MSRP(RMB)"
                    ,"TP(RMB)","Discount(RMB)","Discount Rate","VS Month","VS Change"};
        }
        else 
        {
            titles = new String[]{"日期","车型编码","级别","厂商","车型","排量","排档方式","型号标识","车身形式","上市日期","年式","厂商指导价"
                    ,"最低参考价加权值","折扣(元)","折扣率","VS上月","VS变化"};
        }
        int rowIndex = 0;//行号锁引
        int cellIndex = 0;//列锁引
        Row row = ExportExcelUtil.createRow(s, rowIndex, 400);
        
        CellStyle titleStyle = ExportExcelUtil.getExcelTitleBackgroundStyle(wb);//表格标题样式
        CellStyle textStyle = ExportExcelUtil.getExcelFillTextStyle(wb);//内容文本样式
        CellStyle thousandthStyle = ExportExcelUtil.getExcelFormatThousandthStyle(wb);//格式化千分位样式
        CellStyle percentageStyle = ExportExcelUtil.getExcelFillPercentageStyle(wb);//格式化百分号样式
        
        //保存线图刻度最大值与最小值,供数据部使用
        Cell cell = row.createCell(40);
        ExportExcelUtil.setCellValueAndStyle(cell, AppFrameworkUtil.getNum(paramsMap.get("ymax").toString(), 0)+".0~", textStyle);
        cell = row.createCell(41);
        ExportExcelUtil.setCellValueAndStyle(cell, AppFrameworkUtil.getNum(paramsMap.get("ymin").toString(), 0)+".0~", textStyle);
        cell = row.createCell(42);
        ExportExcelUtil.setCellValueAndStyle(cell, languageType, textStyle);
        
        //写标题
        for(String title : titles)
        {
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, title, titleStyle);
            s.setColumnWidth(cell.getColumnIndex(), 3000);
        }
        //写数据
        for(int i = 0; i < gridObj.size(); i++)
        {
            JSONObject obj = gridObj.getJSONObject(i);
            row = ExportExcelUtil.createRow(s, ++rowIndex, 400);
            cellIndex = 0;
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("yearMonth")+"~", textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("versionCode")+"~", textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"gradeName"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"manfName"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"subModelName"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("discharge"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"gearMode"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"typeId"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, getValueByLanguageType(obj,languageType,"bodyType"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("versionLaunchDate"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("modelYear"), textStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, obj.getString("msrp"), thousandthStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, AppFrameworkUtil.getNum(obj.getString("tp"),7), thousandthStyle);
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, AppFrameworkUtil.getNum(obj.getString("discount"),7), thousandthStyle);
            
            cell = row.createCell(cellIndex++);
            if("".equals(obj.getString("discountRate")) || "-".equals(obj.getString("discountRate"))){
                ExportExcelUtil.setCellValueToPercentage(cell, "-", percentageStyle);
            } else{
                ExportExcelUtil.setCellValueToPercentage(cell, obj.getString("discountRate"), percentageStyle);
            }
            
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, AppFrameworkUtil.getNum(obj.getString("vsDiscount"),7), thousandthStyle);
            
            cell = row.createCell(cellIndex++);
            if("".equals(obj.getString("vsDiscountRate")) || "-".equals(obj.getString("vsDiscountRate"))){
                ExportExcelUtil.setCellValueToPercentage(cell, "-", percentageStyle);
            } else{
                ExportExcelUtil.setCellValueToPercentage(cell, obj.getString("vsDiscountRate"), percentageStyle);
            }
        }
        s.setDisplayGridlines(false);
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容