简介
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表格对象,使用其可以向表格中的列添加内容,达到数据报表导出的功能。