前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java XLSTransformer生成excel文件

Java XLSTransformer生成excel文件

作者头像
全栈程序员站长
发布2022-09-15 10:52:54
5840
发布2022-09-15 10:52:54
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

把页面的数据导出excel 数据

Java XLSTransformer生成excel文件
Java XLSTransformer生成excel文件

然后进入 struts2 action

代码语言:javascript
复制
          <action name="generateExcel" class="com.xx.emidas.activity.activity.ajax.XLSTransformerGenerateExcelAction">
         </action>
代码语言:javascript
复制
package com.xx.emidas.activity.activity.ajax;

import com.xx.combiz.spring.util.LionConfigUtils;
import com.xx.emidas.activity.external.util.XLSTransformerGenerateExcelUtil;
import com.xx.emidas.activity.picture.BaseAction;







import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.apache.struts2.ServletActionContext;








import java.io.File;
import java.io.IOException;
import java.io.Writer;
import java.util.*;

import javax.servlet.http.HttpServletResponse;


public class XLSTransformerGenerateExcelAction extends BaseAction {
	
	private String url;
	private String name;
    /**活动ID*/
    private int activityId;

    /**查询起始日期*/
    private String queryStart;

    /**查询结束日期*/
    private String queryend;
	/**
	 * 
	 */
	private static final long serialVersionUID = 2058361031969467470L;

	@Override
	public String execute() throws Exception {
        try {
        	//url="http://localhost:8080/activities/activity/newClickdate"+"?activityId="+activityId+"&queryStart="+queryStart+"&queryend="+queryend;
        	  url = LionConfigUtils.getProperty("emidas-event.activity.data.excelExport", "0");
        	  url+="?activityId="+activityId+"&queryStart="+queryStart+"&queryend="+queryend;
        	XLSTransformerGenerateExcelUtil.ExportExcel(url, name);
		} catch (Exception e) {
			
		}
       return null;
	}

	public String getUrl() {
		return url;
	}

	public void setUrl(String url) {
		this.url = url;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public int getActivityId() {
		return activityId;
	}

	public void setActivityId(int activityId) {
		this.activityId = activityId;
	}

	public String getQueryStart() {
		return queryStart;
	}

	public void setQueryStart(String queryStart) {
		this.queryStart = queryStart;
	}

	public String getQueryend() {
		return queryend;
	}

	public void setQueryend(String queryend) {
		this.queryend = queryend;
	}
	
	
	
	

}

这里的 url 是你的 需要数据的页面 或者 action 图片也可以显示的

这里是我自己封装的XLSTransformer的工具类

代码语言:javascript
复制
package com.xx.emidas.activity.external.util;


import java.io.IOException;
import java.io.Writer;

import javax.servlet.http.HttpServletResponse;

import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.ClientProtocolException;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import org.apache.struts2.ServletActionContext;
public class XLSTransformerGenerateExcelUtil {
	/**
	 * 导出页面数据生成 xlsx
	 * @author hongwang.zhang
	 * @date 20150826
	 * @param path  url路径
	 * @param name  excel名称
	 */
	public static void  ExportExcel( String path,String name){
		CloseableHttpClient httpClient = HttpClients.createDefault();
        HttpGet httppost = new HttpGet(path);
        try {
            // 发送请求,返回响应
            HttpResponse response = httpClient.execute(httppost);

            // 打印响应信息
            HttpEntity entity = response.getEntity();
            HttpServletResponse x = ServletActionContext.getResponse();
            x.setContentType("application/vnd.ms-excel");  
            String titlename="data"; 
            if(null!=name){
            	titlename=name;
            }
            x.setHeader("Content-Disposition", "attachment;filename="+new String((titlename).getBytes("gbk"),"iso8859-1")+".xlsx");  
              Writer w = null;
              w = x.getWriter();
              w.write(EntityUtils.toString(entity));
              w.flush();
              
              EntityUtils.consume(entity);
            //
        } catch (ClientProtocolException e) {
            // 协议错误
            e.printStackTrace();
        } catch (IOException e) {
            // 网络异常
            e.printStackTrace();
        }
	}
	
	

}

导出来的基本会和页面上的数据 样式一样的,这里我自己做了一个独立的页面 对样式做了一些修改 导出的excel 和页面上的一模一样

Java XLSTransformer生成excel文件
Java XLSTransformer生成excel文件

是不是很吊呢

这里就是大概的代码了,如果有什么 不懂的可以在留言

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/163869.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档