`
heruito
  • 浏览: 16852 次
社区版块
存档分类
最新评论

JAVA 把List 转换成Excel 导出 实例代码 不喜勿喷

 
阅读更多

辅助类代码:

package com.util;

 

import java.io.FileNotFoundException;

import java.io.IOException;

import java.io.OutputStream;

import java.io.UnsupportedEncodingException;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

 

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

 

import mode.Swpsc;

 

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFFont;

import org.apache.poi.hssf.usermodel.HSSFRichTextString;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.hssf.util.HSSFColor;

 

public final class ExcelExport {

OutputStream out =null;

String excelName = "发货统计详单";  

//访问网址:http://localhost:8080/excelExport/servlet/ExcelExportServlet  

    public void Excelexport(HttpServletRequest request, HttpServletResponse response,List<Swpsc> list){  

    try {

response.addHeader("Content-Disposition", "attachment;filename="+new String(excelName.getBytes("UTF-8"),"ISO8859-1")+".xls");

} catch (UnsupportedEncodingException e1) {

// TODO 自动生成的 catch 块

e1.printStackTrace();

}  

       

        //转码防止乱码  

        String[] headers = new String[]{"序号","送货单编号","客户名称","订单编号","印品名称","发货数量","单价","交货日期","总金额"};  

        try {  

        

            out = response.getOutputStream();  

            out.flush();

            exportExcel(excelName,headers, getList(list), out,"yyyy-MM-dd");  

           

            out.close();

            System.out.println("excel导出成功!");  

        } catch (FileNotFoundException e) {  

                e.printStackTrace();  

        } catch (IOException e) {  

                e.printStackTrace();  

        }  

    }  

  

  

    /** 

     *  

     * @Description: 模拟从数据库中查询出来的数据,一般是数据表中的几列 

     * @Auther: lujinyong 

     * @Date: 2013-8-22 下午2:53:58 

     */  

    public List<Map<String,Object>> getList(List<Swpsc> lists){  

        List<Map<String,Object>> list = new ArrayList<Map<String,Object>>();  

        for(int i = 0; i<lists.size();i++){  

            Map<String,Object> map = new HashMap<String, Object>();  

            map.put("xh",i+1);  

            map.put("shbh", lists.get(i).getPsb().getPsb004());  

            map.put("khmz", lists.get(i).getPsb().getUsc().getUsc003());  

            if(lists.get(i).getPsc007().equals("A")){

            map.put("ddbh", lists.get(i).getDdc().getDds().getDds004());

            map.put("ypmz", lists.get(i).getDdc().getDdc004());

            }

            if(lists.get(i).getPsc007().equals("B")){

            map.put("ddbh", lists.get(i).getDda().getDdz().getDdz004());

            map.put("ypmz", lists.get(i).getDda().getDda004());

            }

            if(lists.get(i).getPsc007().equals("C")){

            map.put("ddbh", lists.get(i).getDdf().getDde().getDde004());

            map.put("ypmz", lists.get(i).getDdf().getDdf004());

            }

            map.put("fhsl",lists.get(i).getPsc004() );  

            map.put("dj", lists.get(i).getDj());  

            map.put("jhrq", lists.get(i).getPsb().getZdDate());  

            map.put("zje", lists.get(i).getMoney());  

            list.add(map);  

        }  

        return list;  

    }  

    /** 

     *  

     * @Description: 生成excel并导出到客户端(本地) 

     * @Auther: lujinyong 

     * @Date: 2013-8-22 下午3:05:49 

     */  

    protected void exportExcel(String title,String[] headers,List mapList,OutputStream out,String pattern){  

        //声明一个工作簿  

        HSSFWorkbook workbook = new HSSFWorkbook();  

        //生成一个表格  

        HSSFSheet sheet = workbook.createSheet(title);  

        //设置表格默认列宽度为15个字符  

        sheet.setDefaultColumnWidth(20);  

        //生成一个样式,用来设置标题样式  

        HSSFCellStyle style = workbook.createCellStyle();  

        //设置这些样式  

        style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);  

        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);  

        style.setBorderBottom(HSSFCellStyle.BORDER_THIN);  

        style.setBorderLeft(HSSFCellStyle.BORDER_THIN);  

        style.setBorderRight(HSSFCellStyle.BORDER_THIN);  

        style.setBorderTop(HSSFCellStyle.BORDER_THIN);  

        style.setAlignment(HSSFCellStyle.ALIGN_CENTER);  

        //生成一个字体  

        HSSFFont font = workbook.createFont();  

        font.setColor(HSSFColor.VIOLET.index);  

        font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);  

        //把字体应用到当前的样式  

        style.setFont(font);  

        // 生成并设置另一个样式,用于设置内容样式  

        HSSFCellStyle style2 = workbook.createCellStyle();  

        style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);  

        style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);  

        style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);  

        style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);  

        style2.setBorderRight(HSSFCellStyle.BORDER_THIN);  

        style2.setBorderTop(HSSFCellStyle.BORDER_THIN);  

        style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);  

        style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);  

        // 生成另一个字体  

        HSSFFont font2 = workbook.createFont();  

        font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);  

        // 把字体应用到当前的样式  

        style2.setFont(font2);  

        //产生表格标题行  

        HSSFRow row = sheet.createRow(0);  

        for(int i = 0; i<headers.length;i++){  

            HSSFCell cell = row.createCell(i);  

            cell.setCellStyle(style);  

            HSSFRichTextString text = new HSSFRichTextString(headers[i]);  

            cell.setCellValue(text);  

        }  

        for (int i=0;i<mapList.size();i++) {  

            Map<String,Object> map = (Map<String, Object>) mapList.get(i);  

            row = sheet.createRow(i+1);  

            int j = 0;  

            Object value = null;  

            value=map.get("xh");  

            if(value instanceof Integer){  

                row.createCell(j++).setCellValue(String.valueOf(value));  

            }  

            row.createCell(j++).setCellValue(map.get("shbh").toString());  

            row.createCell(j++).setCellValue(map.get("khmz").toString());  

            row.createCell(j++).setCellValue(map.get("ddbh").toString());  

            row.createCell(j++).setCellValue(map.get("ypmz").toString());  

            value=map.get("fhsl");  

            if(value instanceof Integer){  

             row.createCell(j++).setCellValue(String.valueOf(value));  

            } 

            value=map.get("dj");  

            if(value instanceof Double){  

             row.createCell(j++).setCellValue(String.valueOf(value));  

            } 

            row.createCell(j++).setCellValue(map.get("jhrq").toString()); 

            value=map.get("zje");  

            if(value instanceof Double){  

             row.createCell(j++).setCellValue(String.valueOf(value));  

            } 

        }  

        try {  

            workbook.write(out);  

        } catch (IOException e) {  

            e.printStackTrace();  

        }  

    }  

}

 

 

 

Controller里面调用代码 :

@RequestMapping(value = "/Order_FH_TJ_index")

public ModelAndView indexRequest(HttpServletRequest request,

HttpServletResponse response) throws Exception {

HttpSession httpsession=request.getSession();

ModelAndView mav=new ModelAndView();

//网站是否被关闭,关闭转向close页面

if(!PubMessage.isCloseweb()&&!((Swuse) httpsession.getAttribute("useinfo")).getUse002().equals("admin")){

mav.setViewName("redirect:/close.jsp");

   return mav;

}

   //检测是否是登录状态

if(httpsession.getAttribute("useinfo")==null){

mav.setViewName("redirect:/login.jsp");

   return mav;

}

 

PageBean pb = new PageBean();

if(request.getParameter("othersql")!=null&&!request.getParameter("othersql").isEmpty()) 

pb.setOthersql(request.getParameter("othersql"));

if(request.getParameter("othersql3")!=null&&!request.getParameter("othersql3").isEmpty()) 

pb.setOthersql3(request.getParameter("othersql3"));

if(request.getParameter("othersql4")!=null&&!request.getParameter("othersql4").isEmpty()) 

pb.setOthersql4(request.getParameter("othersql4"));

if(request.getParameter("othersql8")!=null&&!request.getParameter("othersql8").isEmpty()) 

pb.setOthersql8(request.getParameter("othersql8"));

else pb.setOthersql8("Z");

SwpscService swpscService = (SwpscService) SpringContextUtil.getBean("SwpscService");

mav.addObject("pageobj",swpscService.serachList2(pb));

 

if(pb.getOthersql8().equals("P")){

ExcelExport excelExport=new ExcelExport();

       excelExport.Excelexport(request, response, pb.getResultList());

       return null;

}

 

mav.setViewName("Order_FH_tongji");

return mav;

}

 

前台jsp调用按钮:

<button type="button" class="btn btn-success"  style="margin-left:7px;" onClick="excel()">导出excel</button>

 

 

js访问后台Controller里面方法的代码:

function excel() {

var params = [['othersql',$.trim($("#rolename").val().toString())],      ['othersql3',$.trim($("#startDate").val().toString())],

 ['othersql4',$.trim($("#endDate").val().toString())],['othersql8',"P"]];

         form_submit('Order_FH_TJ_index','post',params,'_self');

}

 

 

所需jar包已上传:poi-3.7-20101029.jar

分享到:
评论

相关推荐

    java中,list集合数据导出到excel表格通用工具类

    在Java编程中,将List集合数据导出到Excel表格是一个常见的需求,特别是在数据分析、报表生成或数据导出等场景。本实例提供了一个通用工具类,能够处理多种不同类型的对象集合,实现了最大化的通用性,使得开发者...

    Java导出excel

    在Java编程环境中,导出Excel是一项常见的任务,特别是在数据处理、报表生成以及数据分析等领域。Java提供了多种库来帮助我们实现这个功能,其中最常用的是Apache POI库。Apache POI是一个开源项目,它允许Java程序...

    Freemarker实现excel导出功能

    总结,使用Freemarker实现Excel导出功能,主要是通过模板语言定义Excel的结构,结合数据模型生成内容,再借助像Apache POI这样的库进行转换。这种方式既灵活又高效,尤其适合处理大量结构化数据的导出需求。在实际...

    poi多sheet页导出工具类和实例 包含多个excel导出

    总之,这个 poi 多 sheet 导出工具类和实例是处理大量数据导出的有效方法,结合合理的数据分组、公共数据获取类以及优化策略,可以高效地生成多个 sheet 或多个 Excel 文件,满足大规模数据的导出需求。

    通用excel导入/导出 (poi)

    Apache POI是一个强大的Java库,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。在这个"通用excel导入/导出 (poi)"的示例中,我们主要关注的是Excel文件的处理,特别是如何利用POI库进行数据...

    java实现csv导出千万级数据实例

    本实例聚焦于“java实现csv导出千万级数据实例”,旨在提供一个高效、稳定的解决方案,避免因数据量过大而导致的性能问题,如Java中的栈溢出(Stack Overflow)。CSV(Comma Separated Values)格式因其简单、通用性...

    Java list转excel.zip

    综上所述,“Java list转excel.zip”项目提供了一个基础的Java List到Excel转换的实现,利用Apache POI库,开发者可以轻松地将程序中的数据导出为Excel文件,便于进一步的数据管理和分析。在实际应用中,还可以根据...

    poi excel转换成bean

    标题“poi excel转换成bean”涉及到的关键技术是使用Apache POI从Excel文件中读取数据并将其映射到Java Bean对象中。这个过程在处理大量结构化数据时特别有用,例如导入数据库或进行数据分析。 首先,我们需要理解...

    EXCEL20032007导入导出实例

    总结,"EXCEL20032007导入导出实例"是一个关于如何在Java Web环境下使用Apache POI库实现Excel 2003和2007文件的导入与导出的实践项目。通过这个实例,开发者可以学习到如何处理Excel数据,提升Web应用的功能性和...

    ESHHUeditor 实例Excel导入导出

    用户选择本地的Excel文件后,服务器端会接收到文件内容,通常使用Apache POI或者JExcelAPI这样的Java库解析Excel数据,并将其转换为可处理的格式,如List或Map,然后存储到数据库中。 4. 数据库存:在SHH框架中,...

    ExcelHelper(Excel导入导出)实例源码

    - **导出数据**:相反,它也能将程序中的数据结构转换成Excel格式,方便用户下载或分享。 - **支持多种格式**:ExcelHelper不仅支持旧版的.xls格式,也支持.xlsx格式,覆盖了Excel的广泛版本。 - **自定义映射**...

    将查询结果集导出excel

    这个文件可能包含了如何创建一个简单的Excel导出和解析的示例。通过阅读和理解这个代码,你可以学习如何将数据库查询结果或Java集合转换为Excel文件,以及如何从Excel文件中读取数据。 7. **优化与扩展**:除了基本...

    导出excel实例与资料.zip

    这个“导出excel实例与资料.zip”压缩包包含了一个完整的Java实现导出Excel的示例,以及相关的使用案例和问题解决经验。 首先,让我们探讨Java中导出Excel的基本原理。在Java中,最常用的库是Apache POI,这是一个...

    导出Excel实例项目:dbToExcel

    "dbToExcel"项目就是针对这一需求的一个实例,它旨在帮助用户高效地将数据库中的信息转换为Excel格式,便于进一步处理和分析。 在实际应用中,这个项目可能涉及到以下关键知识点: 1. 数据库连接:为了从数据库中...

    Java生成Excel实例

    ### Java生成Excel实例详解 #### 一、使用DisplayTag实现Excel导出 在Java开发中,经常需要将数据导出为Excel格式以便于用户下载或进一步处理。本节将详细介绍如何利用DisplayTag库来实现这一功能。 ##### 1.1 ...

    js列表数据导出到excel表中

    ### 如何将JavaScript获取的数据导出到Excel表中 在实际工作中,经常需要将系统中的数据导出到Excel表格中以便于进一步分析或共享。本文将详细介绍如何利用JavaScript结合Java后端来实现这一功能。 #### 导出Excel...

    Android 导出数据库到Excel表格功能

    在Android应用开发中,有时需要将应用程序内部的SQLite数据库数据导出到常见的Excel格式,以便用户可以方便地查看、编辑或共享数据。这个过程涉及到Android的数据库操作、文件读写以及与Excel文件格式的交互。以下是...

    java导出Excel通用方法的实例详解

    上述代码是使用Java导出Excel的通用方法,主要涉及了Apache POI库中的jxl包,用于处理Excel文件。下面将详细介绍这个方法的各个部分及其工作原理: 1. **初始化响应对象**:通过`ServletActionContext.getResponse...

    Java导入导出EXCEL (poi)

    "Java导入导出EXCEL(poi)"这个主题主要涉及到如何使用Apache POI来处理Excel数据,包括将Excel数据转化为JavaBean对象以及将JavaBean对象写入Excel。 Apache POI提供了两种主要的API来操作Excel:HSSF(Horrible ...

    EasyExcel导出实体数据

    在Java开发中,数据导出是一项常见的需求,用于将数据库中的数据转化为用户可查看或处理的格式,如Excel。EasyExcel是阿里巴巴推出的一款轻量级的Excel读写框架,它在处理大量数据时表现优秀,且对内存消耗极低。本...

Global site tag (gtag.js) - Google Analytics