Java使用模板导出Excel

导出类如下:

 public String outputEXcel(HttpServletRequest request, HttpServletResponse response) {

        //报表模板路径
        String importFilePath = "/inventory_gap_rate.xlsx";
        //还需要判断文件格式
        File fi = new File(importFilePath);
        if(importFilePath != "" && StringUtil.isNotEmpty(importFilePath) && fi.exists()){

            InputStream in = null;
            XSSFWorkbook wb = null;
            try {
                //excel模板路径
                in = new FileInputStream(fi);
                //读取excel模板
                wb = new XSSFWorkbook(in);
            } catch (FileNotFoundException e) {
                log.error("输入流异常", e);
            } catch (IOException e) {
                e.printStackTrace();
                log.error("读取Excel模板异常", e);
            }
            //判断Sheet的个数,避免出现越界。
            if(wb.getNumberOfSheets() == 2){
                //读取了模板内图表所需数据
                XSSFSheet sheet = wb.getSheetAt(1);
                //获取第一个sheet
                XSSFSheet sheetAboutList = wb.getSheetAt(0);
                //如果这行没有了,整个公式都不会有自动计算的效果的
                sheet.setForceFormulaRecalculation(true);

                //获取信息1
                ArrayList<HashMap<String, Object>> inventoryGapRate = dao.getInventoryGapRate();
                //获取信息2
                ArrayList<HashMap<String, Object>> dailySaleInventoryGap = dao.getDailySaleInventoryGap();

                //导出图表数据
                if (inventoryGapRate != null && inventoryGapRate.size() > 0) {
                    for (int i = 0; i < inventoryGapRate.size(); i++) {
                        setInventoryGapRate(i, sheet, inventoryGapRate);
                    }
                }
                //导出信息数据
                if (dailySaleInventoryGap != null && dailySaleInventoryGap.size() > 0) {
                    for (int i = 0; i < dailySaleInventoryGap.size(); i++) {
                        setDailySaleInventoryGap(i,sheetAboutList,dailySaleInventoryGap);
                    }
                }
            }

            try {
                //下载时文件的名称
                String filename = "导出excel.xlsx";
                //设置编码
                if (request.getHeader("User-Agent").toLowerCase().indexOf("firefox") > 0) {
                    filename = new String(filename.toString().getBytes("utf-8"),  "iso-8859-1");
                } else {
                    filename = URLEncoder.encode(filename.toString(), "UTF-8");
                }
                //文件类型
                response.setContentType("application/vnd.ms-excel");
                //导出文件的信息
                response.setHeader("Content-disposition", "attachment;filename=" + filename);
                OutputStream ouputStream = response.getOutputStream();
                wb.write(ouputStream);
                ouputStream.flush();
                ouputStream.close();

            } catch (IOException e) {
                log.error("写出Excel IO异常", e);
            }
        }else{

        }
        return "";

    }

根据excel模板动态导出数据库数据 package text; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.UUID; import javax.servlet.ServletContext; import net.sf.jxls.transformer.XLSTransformer; import org.apache.struts2.ServletActionContext; import com.opensymphony.xwork2.ActionSupport; public class TextAction extends ActionSupport { /** */ private static final long serialVersionUID = 1L; private String filename; @SuppressWarnings("rawtypes") public String export() throws Exception { String templateFile = "18.xls"; // String sql = "select * from t_ry order by rybm"; // exportAndDownload(templateFile, DataBase.retrieve(sql)); List datas = new ArrayList(); @SuppressWarnings("unchecked") HashMap map = new HashMap(); map.put("name", "1111"); datas.add(map); exportAndDownload(templateFile, datas); return SUCCESS; } @SuppressWarnings({ "rawtypes", "unchecked" }) public void exportAndDownload(String templateFile, List datas) { try { filename = UUID.randomUUID() + templateFile; // FacesContext context = FacesContext.getCurrentInstance(); // ServletContext servletContext = (ServletContext) // context.getExternalContext().getContext(); ServletContext servletContext = ServletActionContext .getServletContext(); String path = servletContext.getRealPath("\\ExcelFile"); String srcFilePath = path + "\\template\\" + templateFile; String destFilePath = path + "\\download\\" + filename; Map beanParams = new HashMap(); beanParams.put("results", datas); XLSTransformer transfer = new XLSTransformer(); transfer.transformXLS(srcFilePath, beanParams, destFilePath); // Browser.execClientScript("window.location.href='../ExcelFile/downloadfile.jsp?filename=" // + destFile + "';"); } catch (Exception e) { e.printStackTrace(); } } public String getFilename() { return filename; } public void setFilename(String filename) { this.filename = filename; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值