java Servlet导出数据到Excel文件
package com.lbc.excel.servlet; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import com.lbc.entity.EquipmentLib;
import com.lbc.entity.OaUsers;
import com.lbc.service.AssetServiceDao;
import com.lbc.service.AssetServiceDaoImpl; import youngPackage.db.YoungRepository; /**
* Servlet implementation class ExportExcelServlet
*/
public class ExportExcelServlet extends HttpServlet {
private static final long serialVersionUID = 1L; /**
* @see HttpServlet#HttpServlet()
*/
public ExportExcelServlet() {
super();
// TODO Auto-generated constructor stub
} /**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
} /**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
System.out.println("---------------------------------ExportExcelServlet----------------------------------");
request.setCharacterEncoding("utf-8");
response.setCharacterEncoding("utf-8");
YoungRepository youngdb = (YoungRepository)request.getSession().getAttribute("oa_db");
OaUsers user = (OaUsers)request.getSession().getAttribute("oa_user");
String eaPer = (String)request.getSession().getAttribute("currentUserEaPerGrade");
if(youngdb == null){
youngdb = new YoungRepository();
}
AssetServiceDao asd = new AssetServiceDaoImpl(youngdb);
List<EquipmentLib> list = new ArrayList<EquipmentLib>();
if("EA1004".equals(eaPer)){
list = asd.getElByUsernameOrDepartmentOrManager(user.getUsername(),"","ALL","1");
}else if("EA1002".equals(eaPer)){
list = asd.getElByUsernameOrDepartmentOrManager("",user.getDepartment(),"","1");
} String fileName = "Excel-" + System.currentTimeMillis() + ".xls";//设置导出的文件名称
StringBuffer sb = new StringBuffer(this.gettable(list));//将表格信息放入内存
String contentType = "application/vnd.ms-excel";//定义导出文件的格式的字符串
String recommendedName = new String(fileName.getBytes(),"iso_8859_1");//设置文件名称的编码格式
response.setContentType(contentType);//设置导出文件格式
response.setHeader("Content-Disposition", "attachment; filename=" + recommendedName );//
response.resetBuffer();
//利用输出输入流导出文件
ServletOutputStream sos = response.getOutputStream();
sos.write(sb.toString().getBytes());
sos.flush();
sos.close();
}
private String gettable(List<EquipmentLib> list ){
StringBuffer table = new StringBuffer();
if(list != null && list.size() > 0){
table.append("<table border='1'><tbody><tr style='height: 35px;background-color:#fff1cc;'><th>序号</th><th>资产类别</th><th>资产名称</th><th>资产数量</th>");
table.append("<th>所在部门</th><th>使用人</th><th>状态</th><th>购置日期</th><th>开始使用日期</th>");
table.append("<th>使用年限</th><th>原值</th><th>品牌</th><th>规格型号</th><th>备注</th></tr>");
String temp = "";
for(int i = 0 ; i < list.size() ; i++){
EquipmentLib el = list.get(i);
if((i+1)%2 == 0){
table.append("<tr style='height: 35px;' bgcolor='#EDEDED'>");
}else{
table.append("<tr style='height: 35px;'>");
}
table.append("<td align='center'>"+(i+1)+"</td>");
table.append("<td align='center'>"+el.getFamily()+"</td>");
table.append("<td align='center'>"+el.getName()+"</td>");
table.append("<td align='center'>"+el.getAmount()+"</td>");
table.append("<td align='center' style='color:red;'>"+el.getDepartment()+"</td>");
table.append("<td align='center'>"+el.getCurrentUserName()+"</td>");
if("2".equals(el.getStatus())){
temp = "资产转移中";
}else if("4".equals(el.getStatus())){
temp = "报废审核中";
}else {
temp = "正常使用";
}
table.append("<td align='center'>"+temp+"</td>");
table.append("<td align='center'>"+el.getPurchaseDate()+"</td>");
table.append("<td align='center'>"+el.getStartUseDate()+"</td>");
table.append("<td align='center'>"+el.getUseLife()+"</td>");
table.append("<td align='center'>"+el.getValue()+"</td>");
if(el.getBrand() == null ){
table.append("<td align='center'></td>");
}else{
table.append("<td align='center'>"+el.getBrand()+"</td>");
} if(el.getSpecifications() == null ){
table.append("<td align='center'></td>");
}else{
table.append("<td align='center'>"+el.getSpecifications()+"</td>");
} if(el.getRemark() == null ){
table.append("<td align='center'></td>");
}else{
table.append("<td align='center'>"+el.getRemark()+"</td>");
} }
table.append("</tr></tbody></table>");
}
return table.toString();
}
}
java Servlet导出数据到Excel文件的更多相关文章
- java代码导出数据到Excel、js导出数据到Excel(三)
jsp内容忽略,仅写个出发按钮: <button style="width: 100px" onclick="expertExcel()&quo ...
- 使用PHP导入Excel和导出数据为Excel文件
有时需要将Excel表格的数据导入到mysql数据库中,我们使用PHP的一个开源项目PHP-ExcelReader可以轻松实现Excel的导入.另外将mysql数据导出为Excel与本站上篇文章中导出 ...
- 从GridView中直接导出数据到Excel文件 处理导出乱码 类型“GridView”的控件“XXXX”必须放在具有 runat=server 的窗体标记内。”的异常
导出到Excel方法: <span style="color: rgb(0, 0, 255);">public</span> <span style= ...
- CodeIgniterCodeigniter+PHPExcel导出数据到Excel文件
解压压缩包里的Classes文件夹中的内容到application\libraries\目录下,目录结构如下:--application\libraries\PHPExcel.php--applica ...
- PHP导出MySQL数据到Excel文件
PHP导出MySQL数据到Excel文件 转载 常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存 ...
- 1.ASP.NET MVC使用EPPlus,导出数据到Excel中
好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...
- 微软BI 之SSIS 系列 - 导出数据到 Excel 2013 的实现
开篇介绍 碰到有几个朋友问到这个问题,比较共性,就特意写了这篇小文章说明一下如何实现在 SSIS 中导出数据到 Office Excel 2013 中.通常情况下 2013 以前的版本大多没有问题,但 ...
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- java 写入数据到Excel文件中_Demo
=======第一版:基本功能实现======= import com.google.common.collect.Maps; import org.apache.log4j.Logger; impo ...
随机推荐
- dos常用文件操作命令
1.DIR 含义: 显示指定目录下的文件和子目录列表 类型: 内部命令 格式: DIR[drive:][path][filename][/p][/w][/A[[:]attributes]][/O[[: ...
- Android4.4 + WebAPI 实现拍照上传
网上有很多关于拍照上传的实现方法,如果用新版本android去运行有可能会发现根本实现不了.主要原因是android从4.4版本开始通过intent.ACTION_GET_CONTENT打开选择器后, ...
- 两个字符串,若为数字则都相加,若有一个不为数字则,输出error
import java.util.*; /*请设计一个算法能够完成两个用字符串存储的整数进行相加操作,对非法输入则返回“error”: * 用例:123 234 * 输出:357 * 用例123 as ...
- Wireshark 过滤条件
做应用识别这一块经常要对应用产生的数据流量进行分析. 抓包采用wireshark,提取特征时,要对session进行过滤,找到关键的stream,这里总结了wireshark过滤的基本语法,供自己以后 ...
- Centos 6.4 python 2.6 升级到 3.5.2
查看python的版本 #python -V Python 1.下载Python-2.5.2 #wget https://www.python.org/ftp/python/3.5.2/Python- ...
- uiatuomator提示shortMsg=java.lang.RuntimeException
自动化要做断言,原本打算使用的testng,因为它断言后就能出结果,还能生成报告,但是在实践过程中,硬是没有成功,所以还是放弃,使用的junit,后面使用的cts框架生成的邮件,现在记录使用junit ...
- Entity Framework 配置
Entity Framework的核心 – EDM(Entity Data Model) EDM概述 实体数据模型,简称EDM,由三个概念组成.概念模型由概念架构定义语言文件 (.csdl)来定义,映 ...
- C#根据WSDL文件生成WebService服务端代码
转自:http://www.cnblogs.com/liyi93/archive/2012/01/30/2332320.html 虽然现在已经进入了.NET FrameWork 4.0的时代,WebS ...
- 2015年校园招聘12家IT公司面试体验
背景 2015年注定是一个不平凡的年头,作为一个应届毕业生,我也算是经历了工作上的大起大落.下面我先简单讲述一下自己的遭遇,然后根据自己亲身的面试经历,从一个学生的角度去谈谈自己对面试过的公司的一些看 ...
- 搭建eclipse+maven+scala-ide的scala web开发环境
http://www.tuicool.com/articles/NBzAzy 江湖传闻,scala开发的最佳利器乃 JetBrains 的神作 IntelliJ IDEA ,外加构建工具sbt 是也. ...