导出数据到EXL表格中
项目使用的是SSI框架,通过struts访问到action
xml文件:
<action name="fabAttributedaochu" class="com.FabAttributeAction" method="daochu" >
<result name="success" type="stream">
<!-- 指定下载文件的文件类型 -->
<param name="contentType">xls</param>
<!-- 指定下载文件的文件位置 -->
<param name="inputName">downExpFile</param>
<!-- 指定下载文件的文件名 -->
<param name="contentDisposition">attachment;filename="${contentDisposition}"</param>
<!-- 指定下载文件的缓冲大小 -->
<param name="bufferSize">4096</param>
</result>
<result name="fail">/fabric/freemarker/finance/report/reportOrder.ftl</result>
</action>
action文件:
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook; private String contentDisposition;//一定要有的属性
public String getContentDisposition() { //get
return contentDisposition;
}
public void setContentDisposition(String contentDisposition) { //set
this.contentDisposition = contentDisposition;
} public String daochu() throws Exception{//前台按导出键跳转到这个方法,可以在这里设一些判断条件是否继续
if(null==biCustomOrderQuantityVo){
biCustomOrderQuantityVo =new BiCustomOrderQuantityVo();
}else {
//Integer total = this.getBuyOrderBo().selectBuyOrderCount(buyOrder);
Integer total= this.getBiCustomOrderQuantityBo().selectbiCustCount(biCustomOrderQuantityVo);
System.out.println("total:"+total);
if(total-0==0){
this.getRequest().setAttribute("message","数据量为0,请重新选择时间段");
return "fail";
}else if(total-65534>=0){
this.getRequest().setAttribute("message", "数量大于65534,请缩小选择范围");
return "fail";
}else{
return success;
}
}
return success;
}
public InputStream getDownExpFile() throws Exception{//根据xml的返回定义了一个get值,进入之个方法,
contentDisposition = java.net.URLEncoder.encode("buyOrder.xls","UTF-8");//指定一个文件的文件名
return fabAttributeBo.daochu();//调用bo层数据返回一个InputStream对象
}
逻辑业务层(bo):
/**
* 导出
* @throws BOException
* @throws FileNotFoundException
* */
public FileInputStream daochu() throws BOException {
try {
List<FabAttributeVo> list =this.getFabAttributeDao().selectFabAttribute(null).getList();//导出数据的集合--数据
Integer rowNumber =list.size();
//创建新的ExCEL
HSSFWorkbook workbook = new HSSFWorkbook();
//创建工作表名
HSSFSheet sheet = workbook.createSheet("标签1");
//定义行
HSSFRow row =null;
//TITlelist为单元格明
List<String > titleList = this.obtainTitleList();//调用已定义好的列抬头
//用数组定义单元格
HSSFCell [] hssfCells = new HSSFCell[titleList.size()];
//设置单元格格式
HSSFCellStyle cellStyle = workbook.createCellStyle();
HSSFDataFormat format = workbook.createDataFormat();
cellStyle.setDataFormat(format.getFormat("@"));
//下面是创建首行
row =sheet.createRow(0);
for(int j=0;j<titleList.size();j++){
hssfCells[j] = row.createCell(j);
hssfCells[j].setCellStyle(cellStyle);
hssfCells[j].setCellValue(titleList.get(j));
}
//下面是创建数据行
for (int i = 1; rowNumber-i>=0; i++) {
row = sheet.createRow(i);
for (int j = 0; j < titleList.size(); j++) {
hssfCells[j]=row.createCell(j);
hssfCells[j].setCellStyle(cellStyle);
hssfCells[j].setCellType(HSSFCell.CELL_TYPE_STRING);
switch (j) {//每一个行需要插入拿一条
case 0:hssfCells[j].setCellValue(list.get(i-1).getAttr_id());break;
case 1:hssfCells[j].setCellValue(list.get(i-1).getType_name());break;
case 2:hssfCells[j].setCellValue(list.get(i-1).getAttr_name());break;
case 3:hssfCells[j].setCellValue(list.get(i-1).getAttr_input_type());break;
case 4:hssfCells[j].setCellValue(list.get(i-1).getAttr_values());break;
case 5:hssfCells[j].setCellValue(list.get(i-1).getSortOrder());break;
}
}
} File file =new File(this.getClass().getClassLoader().getResource("").getPath() + "fabric/tmp/buyOrder.xls");
if(file.exists())file.delete(); //新建一个输出文件流
FileOutputStream fout = new FileOutputStream(file);
//写相应的Excel工作薄
workbook.write(fout);
FileInputStream in= new FileInputStream(file);
fout.close();
return in;
}catch(Exception e){
e.printStackTrace();
} return null;
}
设定表格的首列行:
/**
* 用于列名的设置
*/
private List<String> obtainTitleList(){//自己定义好,你需要的eml表格中的列
List<String> titleList = new ArrayList<String>();
titleList.add("ID");
titleList.add("商品类型名称");
titleList.add("属性名称");
titleList.add("输入类型");
titleList.add("属性值");
titleList.add("排列次序");
return titleList;
}
这样就ok了!!
导出数据到EXL表格中的更多相关文章
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- Python导出数据到Excel表格-NotImplementedError: formatting_info=True not yet implemented
在使用Python写入数据到Excel表格中时出现报错信息记录:“NotImplementedError: formatting_info=True not yet implemented” 报错分析 ...
- 导出数据到Excel表格
开发工具与关键技术:Visual Studio 和 ASP.NET.MVC,作者:陈鸿鹏撰写时间:2019年5月25日123下面是我们来学习的导出数据到Excel表格的总结首先在视图层写导出数据的点击 ...
- 在java中实现数据导入excel表格中
1.首先前端代码如下: 一个导出按钮:<input id="export" class="btn btn-primary" type="butt ...
- jQuery Ajax遍历表格,填充数据,将表格中的数据一条一条拼成Jason数组
$.ajax({ url: baseURL + "InvoiceSale/OnQuotaInvoiceSale", //点击核销单号时,点击核销时,交互的页面 ...
- Scrapy基础(十一)————导出数据到json文件中
之前介绍过将数据写入mysql数据库中,但是对于那些没有数据库的,可以通过写入json文件中或者是写入到csv或者xls:这里只介绍写入json文件中,也为再练习一下自定义的pipeline 思路: ...
- jstl-将List中的数据展示到表格中
功能: 使用jstl将List中的数据动态展示到Jsp表格中,并实现隔行换色功能. 效果图: Jsp代码: <%@ page import="java.util.ArrayList&q ...
- php动态导出数据成Excel表格
一.封装 Excel 导出类 include/components/ExecExcel.php <?php /*** * @Excel 导入导出类. */ class ExecExcel { / ...
- spring boot 使用POI导出数据到Excel表格
在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表 ...
随机推荐
- Kali-linux使用Metasploit基础
Metasploit是一款开源的安全漏洞检测工具.它可以帮助用户识别安全问题,验证漏洞的缓解措施,并对某些软件进行安全性评估,提供真正的安全风险情报.当用户第一次接触Metasploit渗透测试框架软 ...
- 摒弃FORM表单上传图片,异步批量上传照片
之前作图像处理一直在用form表单做图片数据传输, 个人感觉low到爆炸而且用户体验极差,现在介绍一个一部批量上传图片的小技巧,忘帮助他人的同时也警醒自己在代码的编写时不要只顾着方便,也要考虑代码的健 ...
- .net core2 笔记
资源: https://github.com/aspnet/home https://github.com/dotnet/cli https://www.cnblogs.com/billyang/p/ ...
- Django 多表查询练习题 Q查询 F查询 聚合 分组
-------------------------------------------------自己偷的懒,或许用加倍时间也补不回来,珍惜现在的拥有的时光,把我现在! 上节回顾 基于对象的跨表查询( ...
- XML 与 JSON大PK
导读 XML 和 JSON 是现今互联网中最常用的两种数据交换格式.XML 格式由 W3C 于 1996 年提出.JSON 格式由 Douglas Crockford 于 2002 年提出.虽然这两种 ...
- 周末时间学习Linux
大家都是如何度过周末时光的呢?好多人都认为一周的工作后要好好休息下,于是在家疯狂的补觉,刷剧,打游戏,自我觉得很是正常,工作几天了,休息下不是当然嘛.是的,休息下很正常,但是把周末的时光都用到这些东西 ...
- Mike and distribution CodeForces - 798D (贪心+思维)
题目链接 TAG: 这是我近期做过最棒的一道贪心思维题,不容易想到,想到就出乎意料. 题意:给定两个含有N个正整数的数组a和b,让你输出一个数字k ,要求k不大于n/2+1,并且输出k个整数,范围为1 ...
- mysql数据库和JDBC学习
数据库概念: 数据库(Database)是按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库. ---------数据库服务器,mysql(管理) 数据库服务器---->N多库-- ...
- 软件工程(FZU2015) 助教总结
SE_FZU目录:1 2 3 4 5 6 7 8 9 10 11 12 13 本次构建之法-SE助教工作,和福州大学张老师协作,福大学生基本发挥出了一定水平,在此做个小结. 教师 张老师本身的SE教学 ...
- CodeIgniter框架对数据库查询结果进行统计
假设有一个user表,如果要查询符合条件sex=male的记录数量,有下面几种方法: 方法一:先取回所有符合条件的记录,再count $res = $this->db->query(&qu ...