java poi excel 導(dǎo)出實(shí)例

以springMVC為例:
1.controller:

/**
     * 導(dǎo)出
     * @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("價(jià)格監(jiān)測-車型折扣對(duì)比", "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寫到臨時(shí)目錄拐迁,用來獲取文件大小蹭劈,最后刪除
            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);
            
            //關(guān)閉流
            s.flush();
            s.close();
            out.flush();
            out.close();
            
            //記錄導(dǎo)出日志,并刪除臨時(shí)文件
            paramsMap.put("exportSize", AppFrameworkUtil.getNum(f.length()/1024, 0));
            logManager.updateModuleLog(paramsMap);
            f.delete();
            
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

2.serviceImpl:

      /**
       * 導(dǎo)出
       */
    @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");//導(dǎo)出語言
        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")));
                //導(dǎo)圖
                exportLineChartExcel(wb,wb.getSheet("DATA"),gridObj,languageType);
                //導(dǎo)表格
                exportOriginalData(wb,wb.getSheet("原數(shù)據(jù)"),gridObj,languageType,paramsMap);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        return wb;
    }
    
    /**
     * 導(dǎo)出原始數(shù)據(jù)
     * @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;//標(biāo)題數(shù)組
        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[]{"日期","車型編碼","級(jí)別","廠商","車型","排量","排檔方式","型號(hào)標(biāo)識(shí)","車身形式","上市日期","年式","廠商指導(dǎo)價(jià)"
                    ,"最低參考價(jià)加權(quán)值","折扣(元)","折扣率","VS上月","VS變化"};
        }
        int rowIndex = 0;//行號(hào)鎖引
        int cellIndex = 0;//列鎖引
        Row row = ExportExcelUtil.createRow(s, rowIndex, 400);
        
        CellStyle titleStyle = ExportExcelUtil.getExcelTitleBackgroundStyle(wb);//表格標(biāo)題樣式
        CellStyle textStyle = ExportExcelUtil.getExcelFillTextStyle(wb);//內(nèi)容文本樣式
        CellStyle thousandthStyle = ExportExcelUtil.getExcelFormatThousandthStyle(wb);//格式化千分位樣式
        CellStyle percentageStyle = ExportExcelUtil.getExcelFillPercentageStyle(wb);//格式化百分號(hào)樣式
        
        //保存線圖刻度最大值與最小值线召,供數(shù)據(jù)部使用
        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);
        
        //寫標(biāo)題
        for(String title : titles)
        {
            cell = row.createCell(cellIndex++);
            ExportExcelUtil.setCellValueAndStyle(cell, title, titleStyle);
            s.setColumnWidth(cell.getColumnIndex(), 3000);
        }
        //寫數(shù)據(jù)
        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);
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铺韧,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子缓淹,更是在濱河造成了極大的恐慌哈打,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件讯壶,死亡現(xiàn)場離奇詭異料仗,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)伏蚊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門罢维,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人丙挽,你說我怎么就攤上這事肺孵。” “怎么了颜阐?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵平窘,是天一觀的道長。 經(jīng)常有香客問我凳怨,道長瑰艘,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任肤舞,我火速辦了婚禮紫新,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘李剖。我一直安慰自己芒率,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布篙顺。 她就那樣靜靜地躺著偶芍,像睡著了一般。 火紅的嫁衣襯著肌膚如雪德玫。 梳的紋絲不亂的頭發(fā)上匪蟀,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音宰僧,去河邊找鬼材彪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的段化。 我是一名探鬼主播嘁捷,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼穗泵!你這毒婦竟也來了普气?” 一聲冷哼從身側(cè)響起谜疤,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤佃延,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后夷磕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體履肃,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年坐桩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了尺棋。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡绵跷,死狀恐怖膘螟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情碾局,我是刑警寧澤荆残,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站净当,受9級(jí)特大地震影響内斯,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜像啼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一俘闯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧忽冻,春花似錦真朗、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至振诬,卻和暖如春蹭睡,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赶么。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國打工肩豁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓清钥,卻偏偏與公主長得像琼锋,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子祟昭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容