Atitit.导出excel报表的设计与实现java .net php 总结

1. 导出报表 表格的设计要素1

1.1. 支持通用list<Map>转换1

1.2. 对于空列是否输出1

1.3. 支持http web直接输出1

2. Api2

2.1. private static void toExcel(String titles, String filds,List<Map> list,OutputStream outStrm)2

2.2. Response版 toExcel(String titles, String filds,List<ati> li,HttpServletResponse response )2

2.3. File版  toExcel(String titles, String filds,List<Map> list,String outputFilePath)2

3. Php版本PHPExcel4

1. 导出报表 表格的设计要素

1.1. 支持通用list<Map>转换

1.2. 对于空列是否输出

1.3. 支持http web直接输出

作者:: 绰号:老哇的爪子(EAGLE paw,鹰爪,简称爪子)   全名简写:Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

转载请注明来源: http://www.cnblogs.com/attilax/

2. Api

2.1. private static void toExcel(String titles, String filds,List<Map> list,OutputStream outStrm)

2.2. Response版 toExcel(String titles, String filds,List<ati> li,HttpServletResponse response )

2.3. File版  toExcel(String titles, String filds,List<Map> list,String outputFilePath)

public static void toExcel(String titles, String filds,List<Map> list,String outputFilePath) throws Exception {

// 第一步,创建一个webbook,对应一个Excel文件

HSSFWorkbook wb = new HSSFWorkbook();

// 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet

HSSFSheet sheet = wb.createSheet("sheet1");

// 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short

HSSFRow row = sheet.createRow((int) 0);

// 第四步,创建单元格,并设置值表头 设置表头居中

HSSFCellStyle style = wb.createCellStyle();

style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式

String[] tit_arr=titles.split(",");

int n=0;

for(String tit:tit_arr)

{

HSSFCell cell = row.createCell((short) n);

cell.setCellValue(tit);

//cell.set

cell.setCellStyle(style);

n++;

}

// 第五步,写入实体数据 实际应用中这些数据从数据库得到,

for (int i = 0; i < list.size(); i++)

{

row = sheet.createRow((int) i + 1);

Map stu = (Map) list.get(i);

// 第四步,创建单元格,并设置值

int colIndex=0;

for(String tit:tit_arr)

{

String  curField=getFild(filds,colIndex);

Object v = stu.get(curField);

if(v==null) v="";

//String val =v.toString();

//// try{

////  val= v.toString();

//// }catch(Exception e){}

//if(val==null)continue;

HSSFCell cell = row.createCell((short) colIndex);

if(v instanceof Integer)

cell.setCellValue(Double.valueOf(v.toString()));

else

cell.setCellValue(v.toString());

//cell.setCellStyle(style);

colIndex++;

}

}

// 第六步,将文件存到指定位置

try

{

//String outputFilePath = "E:/students.xls";

FileOutputStream fout = new FileOutputStream(outputFilePath);

wb.write(fout);

fout.close();

}

catch (Exception e)

{

e.printStackTrace();

}

}

3. Php版本PHPExcel

参考

atitit.查询结果 导出为excel的实现java .net php 总结

Atitit.导出excel报表的设计与实现java .net php 总结的更多相关文章

  1. Atitit.导出excel报表的设计与实现java .net php 总

    Atitit.导出excel报表的设计与实现java .net php 总结 1. 导出报表 表格的设计要素1 1.1. 支持通用list<Map>转换1 1.2. 对于空列是否输出1 1 ...

  2. Atitit.导出excel功能的设计 与解决方案

    Atitit.导出excel功能的设计 与解决方案 1.1. 项目起源于背景1 1.2. Js  jquery方案(推荐)jquery.table2excel1 1.3. 服务器方案2 1.4. 详细 ...

  3. atitit.导出excel的设计----查询结果 导出为excel的实现java .net php 总结

    atitit.导出excel的设计----查询结果 导出为excel的实现java .net php 总结 1. 基本的流程 查询获得list 读取jsp的table获得标题and 字段的map to ...

  4. 从数据库中导出excel报表

    通常需要将后台数据库中的数据集或者是其他列表等导出excel 报表,这里主要引用了Apose.cells dll 类库, (1)直接上主要代码: protected void txtExport_Cl ...

  5. poi导出Excel报表多表头双层表头、合并单元格

    效果图: controller层方法: /**     *      * 导出Excel报表     * @param request     * @return     *      */    @ ...

  6. java导出excel报表

    1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;impo ...

  7. Java使用POI实现数据导出excel报表

    Java使用POI实现数据导出excel报表 在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅 ...

  8. 根据模板导出Excel报表并生成多个Sheet页

    因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为  根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...

  9. 根据模板导出Excel报表并复制模板生成多个Sheet页

    因为最近用报表导出比较多,所有就提成了一个工具类,本工具类使用的场景为  根据提供的模板来导出Excel报表 并且可根据提供的模板Sheet页进行复制 从而实现多个Sheet页的需求, 使用本工具类时 ...

随机推荐

  1. 32、Django实战第32天:我的收藏

    我的收藏有3个页面:课程机构,授课教师,公开课程 课程机构 1.编辑usercenter-fav-org.html继承usercenter-base.html 2.编辑users.views.py . ...

  2. java中的3大特性之多态

    一.多态:一个对象具有多种表现形态(父类的引用类型变量指向了子类的对象) 二.多态的满足条件:1.必须要有继承关系2.必须要有方法的重写 三.int[]a; //a引用类型变量-->//引用in ...

  3. Java加密解密大全

    ChinaSEI系列讲义(By 郭克华)   Java加密解密方法大全                     如果有文字等小错,请多包涵.在不盈利的情况下,欢迎免费传播. 版权所有.郭克华 本讲义经 ...

  4. [xsy1515]小学生数学题

    题意:求$\begin{align*}\left(\sum\limits_{i=1}^n\dfrac 1i\right)\%\ p^k\end{align*}$ 数学真是太可爱了== 直接推公式 设$ ...

  5. [CF864F]Cities Excursions

    题目大意: 一个$n(n\le3000)$个点的有向图,$q(q\le4\times10^5)$组询问,每次询问$s_i,t_i$之间是否存在一条字典序最小的路径(可以重复经过不为$t_i$的结点). ...

  6. [CodePlus2017NOV]晨跑

    题目大意: 三个人分别以a,b,c的速度在一个圈上晨跑,在时间为0时,他们一起出发,问何时能相遇? 思路: lcm(a,b,c)即可. #include<cstdio> #include& ...

  7. 十. 图形界面(GUI)设计11.对话框

    对话框是为了人机对话过程提供交互模式的工具.应用程序通过对话框,或给用户提供信息,或从用户获得信息.对话框是一个临时窗口,可以在其中放置用于得到用户输入的控件.在Swing中,有两个对话框类,它们是J ...

  8. 生成随机位数的UUID

    1,生成UUID package com.jeeplus.common.utils; import java.util.UUID; /** * 生成唯一的UUID * * @author songya ...

  9. 关于Block Formatting Context--BFC和IE的hasLayout(转)

    转文请标明 --- 出处:穆乙 http://www.cnblogs.com/pigtail/ 一.BFC是什么? BFC(Block Formatting Context)直译为“块级格式化范围”. ...

  10. jQuery的deferred对象详解(转)

    jQuery的开发速度很快,几乎每半年一个大版本,每两个月一个小版本. 每个版本都会引入一些新功能.今天我想介绍的,就是从jQuery 1.5.0版本开始引入的一个新功能----deferred对象. ...