Struts2 java 对象 导出Excel

从数据库中导出对象信息到Excel 有多种方式,这里我介绍一种:

1、我的项目使用框架:struts2 + spring + hibernate + mysql

2、另外需要导入poi-3.2-FINAL.jar 包

3、使用反射机制动态执行对象方法,动态确定当前对象。

 

-、配置Action.xml文件

<action name="exportExcel"  class="com.wng.action.addressBook.AddressBookAction" method="exportToExcel">  

<!--返回类型为stream -->
   <result name="success"  type="stream"> 

 <!--文件格式 --> 
    <param name="contentType">application/vnd.ms-excel</param>

<!--action 中inputName 参数名excelStream -->
    <param name="inputName">excelStream</param> 

<!--导出文件名 --> 
    <param name="contentDisposition">attachment;filename="${fileName}.xls"</param>

<!-- -->
     <param name="bufferSize">1024</param>
   </result> 

<!-- -->  
   <result name="error">/index.jsp</result>
  </action>

二、Action中方法代码:

package com.wng.action.addressBook;

import java.io.InputStream;
import java.util.HashMap;
import javax.annotation.Resource;
import com.wng.action.ActionBase;
import com.wng.domain.addressBook.AddressBook;
import com.wng.domain.addressBook.AddressBookGroup;
import com.wng.domain.user.User;
import com.wng.service.impl.addressBook.AddressBookGroupServiceImpl;
import com.wng.service.impl.addressBook.AddressBookServiceImpl;
import com.wng.service.impl.user.UserServiceImpl;
import com.wng.util.GridData;
import com.wng.util.PageData;

public class AddressBookAction extends ActionBase {
 private static final long serialVersionUID = 841738988024332218L;
 private User user;
 
 private AddressBookGroupServiceImpl addressBookGroupServiceImpl;
 private AddressBook addressBook;
 public String fileName = null;
 public  InputStream excelStream;
 

 public AddressBookGroupServiceImpl getAddressBookGroupServiceImpl() {
  return addressBookGroupServiceImpl;
 }

 private AddressBookServiceImpl addressBookServiceImpl;
 
 public AddressBookServiceImpl getAddressBookServiceImpl() {
  return addressBookServiceImpl;
 }
 @Resource(name="addressBookServiceImpl")
 public void setAddressBookServiceImpl(
   AddressBookServiceImpl addressBookServiceImpl) {
  this.addressBookServiceImpl = addressBookServiceImpl;
 }

 

public String exportToExcel() throws Exception{
  if(!isNull(user)){

//导出文件名 
   this.fileName = "fileExport2"; // 设置 fileName 
    excelStream = this.addressBookServiceImpl.exportToExcel(user,addressBookGroup);
    return SUCCESS;
  }else{
   excelStream = null;
   return ERROR;
  }
 }
}


三、业务类中的方法:

package com.wng.service.impl.addressBook;

import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.springframework.stereotype.Component;
import com.wng.dao.impl.addressBook.AddressBookDAOImpl;
import com.wng.domain.addressBook.AddressBook;
import com.wng.domain.addressBook.AddressBookGroup;
import com.wng.domain.user.User;
import com.wng.service.ServiceBase;
import com.wng.service.impl.user.UserServiceImpl;
import com.wng.util.ExportExcel;
import com.wng.util.GridData;
import com.wng.util.WhereHql;
import com.wng.util.WhereItem;

@Component("addressBookServiceImpl")
public class AddressBookServiceImpl extends ServiceBase {
 private AddressBookDAOImpl addressBookDAOImpl;
 private UserServiceImpl userServiceImpl;
 private AddressBookGroupServiceImpl addressBookGroupServiceImpl;
 
 
 public AddressBookGroupServiceImpl getAddressBookGroupServiceImpl() {
  return addressBookGroupServiceImpl;
 }
 @Resource(name="addressBookGroupServiceImpl")
 public void setAddressBookGroupServiceImpl(
   AddressBookGroupServiceImpl addressBookGroupServiceImpl) {
  this.addressBookGroupServiceImpl = addressBookGroupServiceImpl;
 }

 public UserServiceImpl getUserServiceImpl() {
  return userServiceImpl;
 }
 
 @Resource(name="userServiceImpl")
 public void setUserServiceImpl(UserServiceImpl userServiceImpl) {
  this.userServiceImpl = userServiceImpl;
 }

 public AddressBookDAOImpl getAddressBookDAOImpl() {
  return addressBookDAOImpl;
 }
 
 @Resource(name="addressBookDAOImpl")
 public void setAddressBookDAOImpl(AddressBookDAOImpl addressBookDAOImpl) {
  this.addressBookDAOImpl = addressBookDAOImpl;
 }

 

public GridData findByUser(Map<?, ?>  params) {
  // 查出要显示的
  String hql = "From AddressBook a";
  // 总记录数
  String thql = "select count(*) from AddressBook a ";
  GridData gd = new GridData();
  if(isNull(params)){
   return gd;
  }else{
  
   // 从传过来的参数Map中得到查询条件,设置到对像中。
   List<WhereItem> whem = new ArrayList<WhereItem>();
   
   if(!isNull(params.get("user_id"))){
    User user = this.userServiceImpl.get((Long)params.get("user_id"));
    whem.add(new WhereItem("a.user", "=", user));
   }
   
   if(!isNull(params.get("addressBookGroup_id"))){
    AddressBookGroup addressBookGroup = this.addressBookGroupServiceImpl.getById((Long)params.get("addressBookGroup_id"));
    whem.add(new WhereItem("a.addressBookGroup", "=", addressBookGroup));
   }
    // 产生条件语句
    WhereHql whql = createHqlWhere(whem);
    if (!isNull(whql.getHql())) {
     hql = hql + " where " + whql.getHql();
     thql = thql + " where " + whql.getHql();
    }
    // 分页显示
    gd = (this.queryForPage(hql, whql.getParamsAsArray(), thql, whql
      .getParamsAsArray(), (String)params.get("start"), (String)params.get("limit")));
    System.out.println("this number is:" + gd.getTotalRows());
    System.out.println(gd.getDatals().size());
    return gd;
  }
 }

 

 

public InputStream exportToExcel(User user,AddressBookGroup addressBookGroup){
  Map<String, Long> params = new HashMap<String, Long>();
  params.put("user_id", user.getId());
  if(!isNull(addressBookGroup)){
   params.put("addressBookGroup_id", addressBookGroup.getId());
  }
  List<AddressBook> datalist = (List<AddressBook>) findByUser(params).getDatals();
  //声明Excel WorkBook 对象
  HSSFWorkbook workbook = new HSSFWorkbook();
  HSSFSheet sheet = workbook.createSheet();
  //定义导出的Excel 表头栏
  String [] headString = {"编号","姓名","工作单位","电话","QQ号码","性别","联系地址","个人主页","邮件","移动电话","MSN号码","分组"};
  //调用辅助类生成Excel
  ExportExcel<AddressBook> exce = new ExportExcel<AddressBook>(workbook, sheet );
  exce.createNormalHead(null, "枫叶飞扬—通迅录", headString.length);
  //生成表格表头栏
  exce.createColumHeader(headString);
  //传入数据对象类型
  AddressBook addressBook = new AddressBook();
  String [] att = {"Id","Name","Company","Telephone","QqNumber","Sex","Address","WebPage","Email","Moblie","MsnNumber"};
  //生成数据行
  exce.cteateRow((int)2,datalist,addressBook,att);
  //输出ImputStream 供页面下载
  return exce.getExcelImputStream("testfile");
 }

 

四、导出Excel 通用类,使用反射自动执行get 方法

package com.wng.util;

import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Method;
import java.util.List;
import org.apache.commons.io.output.ByteArrayOutputStream;
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.CellRangeAddress;
import org.apache.poi.hssf.util.HSSFColor;

/**
 * 创建通用EXCEL导出通用类
 * @param <T>
 * @param workbook 定义工作簿对象
 * @param sheet 工作表
 *
 */
public class ExportExcel<T> {
 private HSSFWorkbook workbook =null;
 private HSSFSheet sheet = null;
 
 public HSSFWorkbook getWorkbook() {
  return workbook;
 }

 public void setWorkbook(HSSFWorkbook workbook) {
  this.workbook = workbook;
 }

 public HSSFSheet getSheet() {
  return sheet;
 }
 
 public void setSheet(HSSFSheet sheet) {
  this.sheet = sheet;
 }
 
 public ExportExcel(HSSFWorkbook workbook, HSSFSheet sheet) {
  super();
  this.workbook = workbook;
  this.sheet = sheet;
 }
 
 /**
  * 创建通用EXCEL头部
  *
  * @param headString 头部显示的字符
  * @param colSum 该报表的列数
  */
 public void createNormalHead(String headString, String TextString, int colSum) {
  HSSFRow row = sheet.createRow(0);
  // 设置第一行
  HSSFCell cell = row.createCell(0);
  row.setHeight((short) 400);

  // 定义单元格为字符串类型
  cell.setCellType(HSSFCell.ENCODING_UTF_16);
  cell.setCellValue(new HSSFRichTextString(TextString));

  // 指定合并区域
  sheet.addMergedRegion(new CellRangeAddress(0,0,0,(short) colSum-1));
  HSSFCellStyle cellStyle = workbook.createCellStyle();

  cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 指定单元格居中对齐
  cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 指定单元格垂直居中对齐
  cellStyle.setWrapText(true);// 指定单元格自动换行

  // 设置单元格字体
  HSSFFont font = workbook.createFont();
  font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  font.setFontName("宋体");
  font.setFontHeight((short) 300);
  cellStyle.setFont(font);
  cell.setCellStyle(cellStyle);
 }
 
 /**
  * 设置报表标题
  *
  * @param columHeader 标题字符串数组
  */
 public void createColumHeader(String[] columHeader) {
  // 设置列头
  HSSFRow row1 = sheet.createRow(1);
  // 指定行高
  row1.setHeight((short) 300);

  HSSFCellStyle cellStyle = workbook.createCellStyle();
  cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 指定单元格居中对齐
  cellStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 指定单元格垂直居中对齐
  cellStyle.setWrapText(true);// 指定单元格自动换行

  // 单元格字体
  HSSFFont font = workbook.createFont();
  font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  font.setFontName("宋体");
  font.setFontHeight((short) 200);
  cellStyle.setFont(font);
  
  cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 设置单无格的边框为粗体
  cellStyle.setBottomBorderColor(HSSFColor.BLACK.index); // 设置单元格的边框颜色.
  cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  cellStyle.setLeftBorderColor(HSSFColor.BLACK.index);
  cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
  cellStyle.setRightBorderColor(HSSFColor.BLACK.index);
  cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
  cellStyle.setTopBorderColor(HSSFColor.BLACK.index);
  
  // 设置单元格背景色
  cellStyle.setFillForegroundColor(HSSFColor.GREY_25_PERCENT.index);
  cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

  HSSFCell cell3 = null;

  for (int i = 0; i < columHeader.length; i++) {
   cell3 = row1.createCell(i);
   cell3.setCellType(HSSFCell.ENCODING_UTF_16);
   cell3.setCellStyle(cellStyle);
   cell3.setCellValue(new HSSFRichTextString(columHeader[i]));
  }
 }
 
 /**
  * 创建数据行
  * @param rowId 开始行号
  * @param dataList对象list
  * @param  att 需要导出的属性,如{"Name","Age"}
  */
 public void cteateRow(int rowId, List<T> dataList,T ob,String [] att) {
  for(int j = 0; j < dataList.size(); j++){
   HSSFRow row = sheet.createRow(rowId + j);
   for(int i = 0; i < att.length; i++){
    Object obj = this.getter(dataList.get(j), att[i]);
    if(null == obj){
     obj = "";
    }
    cteateCell(workbook,row,i,HSSFCellStyle.ALIGN_CENTER,obj.toString());
   }
  }
 }
  
 /**
  * 创建内容单元格
  *
  * @param workbook HSSFWorkbook
  * @param row HSSFRow
  * @param col short型的列索引
  * @param align 对齐方式
  * @param val 列值
  */
 public void cteateCell(HSSFWorkbook workbook, HSSFRow row, int col,
   short align, String val) {
  HSSFCell cell = row.createCell(col);
  cell.setCellType(HSSFCell.ENCODING_UTF_16);
  cell.setCellValue(new HSSFRichTextString(val));
  HSSFCellStyle cellstyle = workbook.createCellStyle();
  cellstyle.setAlignment(align);
  cell.setCellStyle(cellstyle);
 }
 /**
  * 输入EXCEL文件
  *
  * @param fileName 文件名包含本地路径 如:E:\\test.xls
  */
 public void outputExcel(String fileName) {
  FileOutputStream fos = null;
  try {
   fos = new FileOutputStream(new File(fileName));
   workbook.write(fos);
   fos.close();
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }
 }
 /**
     * @param obj
     *            操作的对象
     * @param att
     *            操作的属性
     * @param value
     *            设置的值
     * @param type
     *            参数的属性
     * */
    public  void setter(Object obj, String att, Object value, Class<?> type) {
        try {
            Method method = obj.getClass().getMethod("set" + att, type);
            method.invoke(obj, value);
        } catch (Exception e) {
            e.printStackTrace();
        }

    }
 
  /**
     * @param obj
     *            操作的对象
     * @param att
     *            操作的属性
     * */
    public Object getter(Object obj, String att) {
     System.out.println(obj.getClass());
     System.out.println(att);
        try {
            Method method = obj.getClass().getMethod("get" + att);
            return method.invoke(obj);
        } catch (Exception e) {
            e.printStackTrace();
        }
  return null;

    }
    /**
     * 输出 Imputstream
     * @param fileName
     *            文件名称
     * @param excelStream Action 和 Action.xml 文件中定义的参数,名称要一至
     * */
    public InputStream getExcelImputStream(String fileName){
   ByteArrayOutputStream baos = new ByteArrayOutputStream();
   InputStream  excelStream = null;
   try {
   workbook.write(baos);
   baos.flush();  
    byte[] aa = baos.toByteArray(); 
    excelStream = new ByteArrayInputStream(aa, 0, aa.length);
    baos.close();
  } catch (IOException e) {
   e.printStackTrace();
  } 
   return excelStream;
 }
 
}

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
数字乡村和智慧农业的数字化转型是当前农业发展的新趋势,旨在通过应用数字技术,实现农业全流程的再造和全生命周期的管理服务。中国政府高度重视这一领域的发展,提出“数字中国”和“乡村振兴”战略,以提升国家治理能力,推动城乡融合发展。 数字乡村的建设面临乡村治理、基础设施、产业链条和公共服务等方面的问题,需要分阶段实施《数字乡村发展战略纲要》来解决。农业数字化转型的需求包括满足市民对优质农产品的需求、解决产销对接问题、形成优质优价机制、提高农业劳动力素质、打破信息孤岛、提高农业政策服务的精准度和有效性,以及解决农业融资难的问题。 数字乡村建设的关键在于构建“1+3+4+1”工程,即以新技术、新要素、新商业、新农民、新文化、新农村为核心,推进数据融合,强化农业大数据的汇集功能。数字农业大数据解决方案以农业数字底图和数据资源为基础,通过可视化监管,实现区域农业的全面数字化管理。 数字农业大数据架构基于大数据、区块链、GIS和物联网技术,构建农业大数据中心、农业物联网平台和农村综合服务指挥决策平台三大基础平台。农业大数据中心汇聚各类涉农信息资源和业务数据,支持大数据应用。信息采集系统覆盖市、县、乡、村多级,形成高效的农业大数据信息采集体系。 农业物联网平台包括环境监测系统、视频监控系统、预警预报系统和智能控制系统,通过收集和监测数据,实现对农业环境和生产过程的智能化管理。综合服务指挥决策平台利用数据分析和GIS技术,为农业决策提供支持。 数字乡村建设包括三大服务平台:治理服务平台、民生服务平台和产业服务平台。治理服务平台通过大数据和AI技术,实现乡村治理的数字化;民生服务平台利用互联网技术,提供各类民生服务;产业服务平台融合政企关系,支持农业产业发展。 数字乡村的应用场景广泛,包括农业生产过程、农产品流通、农业管理和农村社会服务。农业生产管理系统利用AIoT技术,实现农业生产的标准化和智能化。农产品智慧流通管理系统和溯源管理系统提高流通效率和产品追溯能力。智慧农业管理通过互联网+农业,提升农业管理的科学性和效率。农村社会服务则通过数字化手段,提高农村地区的公共服务水平。 总体而言,数字乡村和智慧农业的建设,不仅能够提升农业生产效率和管理水平,还能够促进农村地区的社会经济发展,实现城乡融合发展,是推动中国农业现代化的重要途径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值