POI报表(Java)

简介

POI日志报表在java开发中是经常可以用到的一个功能,可以使用它进行数据库的数据输出,输出为Excel表格形式,废话不多说,直接上代码(从前端到后端的代码)

1.在pom.xml文件中导入POI依赖

<!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
<dependency>
	<groupId>org.apache.poi</groupId>
	<artifactId>poi</artifactId>
	<version>3.6</version>
</dependency>

2.创建并引入工具类

package com.yq.util;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

public class ExcelUtil {

    /**
     * 导出Excel
     * @param sheetName sheet名称
     * @param title 标题
     * @param values 内容
     * @param wb HSSFWorkbook对象
     * @return
     */
    public static HSSFWorkbook getHSSFWorkbook(String sheetName,String []title,String [][]values, HSSFWorkbook wb){

        // 第一步,创建一个HSSFWorkbook,对应一个Excel文件
        if(wb == null){
            wb = new HSSFWorkbook();
        }

        // 第二步,在workbook中添加一个sheet,对应Excel文件中的sheet
        HSSFSheet sheet = wb.createSheet(sheetName);

        // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制
        HSSFRow row = sheet.createRow(0);

        // 第四步,创建单元格,并设置值表头 设置表头居中
        HSSFCellStyle style = wb.createCellStyle();
        style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式

        //声明列对象
        HSSFCell cell = null;

        //创建标题
        for(int i=0;i<title.length;i++){
            cell = row.createCell(i);
            cell.setCellValue(title[i]);
            cell.setCellStyle(style);
        }

        //创建内容
        for(int i=0;i<values.length;i++){
            row = sheet.createRow(i + 1);
            for(int j=0;j<values[i].length;j++){
                //将内容按顺序赋给对应的列对象
                row.createCell(j).setCellValue(values[i][j]);
            }
        }
        return wb;
    }
}

3.前端页面代码

<button id="export" class="btn btn-default" ng-click="exportExcel()">导出Excel</button>  
//点击事件需要使用js指令,其他的好像发送不出去请求
<script type="text/javascript">
	$('#export').click(function(){
		var receiver = $('#receiver').val();
		var receiverMobile = $('#receiverMobile').val();
		var orderId = $('#orderId').val();
		var status = $('#status').val();
		var sourceType = $('#sourceType').val();
		window.location.href="../order/exportExcel.do?receiver="+receiver+"&receiverMobile="+receiverMobile+"&orderId="+orderId+"&status="+status+"&sourceType="+sourceType;
	});
</script>

4.控制层(controller)代码

//导出Excel
@RequestMapping("/exportExcel")
public void exportExcel(String receiver,String receiverMobile,Long orderId,String status,String sourceType,HttpServletRequest request,HttpServletResponse response) {
	//将查询的条件封装到order中(按照条件查询导出excel文件)
	TbOrder order = new TbOrder();
	order.setReceiver(receiver);
	order.setReceiverMobile(receiverMobile);
	order.setOrderId(orderId);
	order.setStatus(status);
	order.setSourceType(sourceType);
	//根据条件查询出订单集合(orderService是持久层的接口实现类,亦为从数据库查询到到处结果)
	List<TbOrder> list = orderService.export(order);
	//excel标题
	String[] title= {"订单编号","用户账号","收货人","手机号","订单金额","支付方式","订单来源","订单状态"};
	//excel文件名
	String fileName="订单信息表"+System.currentTimeMillis()+".xls";
	//sheet名
	String sheetName = "订单信息";
	//二维数组用于装要导出的数据(初始化二维数组)
	String [][] content = new String[list.size()][title.length];
	//循环将数据导入到excel
	for (int i = 0; i < list.size(); i++) {
		TbOrder obj = list.get(i);
		content[i][0]=obj.getOrderId()+"";
		content[i][1]=obj.getUserId()+"";
		content[i][2]=obj.getReceiver()+"";
		content[i][3]=obj.getReceiverMobile()+"";
		content[i][4]=obj.getPayment().toString()+"";
		if("1".equals(obj.getPaymentType()+"")) {
			content[i][5]="在线支付";
		}else if("2".equals(obj.getPaymentType()+"")) {
			content[i][5]="货到付款";
		}else {
			content[i][5]="其他";
		}
		
		if("2".equals(obj.getSourceType()+"")) {
			content[i][6]="pc端";
		}else {
			content[i][6]="其他";
		}
		
		if("1".equals(obj.getStatus()+"")) {
			content[i][7]="未付款";
		}else if("2".equals(obj.getStatus()+"")) {
			content[i][7]="已付款";
		}else if("3".equals(obj.getStatus()+"")) {
			content[i][7]="未发货";
		}else if("4".equals(obj.getStatus()+"")) {
			content[i][7]="已发货";
		}else if("5".equals(obj.getStatus()+"")) {
			content[i][7]="交易成功";
		}else if("6".equals(obj.getStatus()+"")) {
			content[i][7]="交易关闭";
		}else if("7".equals(obj.getStatus()+"")) {
			content[i][7]="待评价";
		}else {
			content[i][7]="其他";
		}
	 }
	//创建HSSFWorkbook
	HSSFWorkbook wb = ExcelUtil.getHSSFWorkbook(sheetName, title, content, null);
	
	//响应到客户端
	try {
		this.setResponseHeader(response, fileName);
		OutputStream os = response.getOutputStream();
		wb.write(os);
		os.flush();
		os.close();
	} catch (Exception e) {
		e.printStackTrace();
	}
}
//发送响应流方法(在上面的方法中被调用了)
public void setResponseHeader(HttpServletResponse response, String fileName) {
	try {
		try {
			fileName = new String(fileName.getBytes(),"ISO8859-1");
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		response.setContentType("application/octet-stream;charset=ISO8859-1");
		response.setHeader("Content-Disposition", "attachment;filename="+ fileName);
		response.addHeader("Pargam", "no-cache");
		response.addHeader("Cache-Control", "no-cache");
	} catch (Exception ex) {
		ex.printStackTrace();
	}
}

注意:
在类中有个HSSFWorkbook的对象,此对象相当与创建的Excel表格对象,使用其可以向表格中的列添加内容,达到数据报表导出的功能。

发布了21 篇原创文章 · 获赞 10 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/weixin_44167913/article/details/88391319