通常需要将后台数据库中的数据集或者是其他列表等导出excel 报表,这里主要引用了Apose.cells dll 类库,

(1)直接上主要代码:

protected void txtExport_Click(object sender, EventArgs e)         {

try             {

// 获取测试商品报表

IList<ProductEntity> pList = ProductBLL.getProductList();

// 导出到Excel中

Workbook workbook = new Workbook();

Worksheet sheet = workbook.Worksheets[0];

Cells cells = sheet.Cells;//单元格

for (int i = 0; i < 3; i++)        {

cells.SetColumnWidth(i, 20);

}

cells[1, 0].PutValue("商品序号");

cells[1, 1].PutValue("商品名称");

cells[1, 2].PutValue("描述");

for (int i = 0; i < pList.Count; i++)                 {

var p = pList[i];

cells[2 + i, 0].PutValue(p.Number);

cells[2 + i, 1].PutValue(p.Name);

cells[2 + i, 2].PutValue(p.Description);

}

string fileName = "商品列表报表" + DateTime.Now.ToString("yyyy.MM.dd.HH.mm.ss.ms") + ".xls";

string saveFileName = HttpContext.Current.Server.MapPath(@"\ExportFile\" + fileName);

workbook.Save(saveFileName);

Label1.Text = "导出报表成功!";

}

catch (Exception ex)             {

Label1.Text = "导出报表失败,原因:" + ex.Message;             }

}

(2)获取ProductList 的方法getProductList():

public static IList<ProductEntity> getProductList(){

IList<ProductEntity> productList = new List<ProductEntity>();

DataTable dt = ProductDAL.getProductList();

if(dt!=null && dt.Rows.Count>0)

{

productList =DatatableToObject.ConvertToList<ProductEntity>(dt);

}

return productList;

}

(3) 顺便介绍比较实用用的DataToObject.ConvertToList<T>() 方法,可以直接将从数据库中读取的DataTable 转化成列表List<T>,

最近才在上面写文章,不会自动对齐格式哈。

public class DatatableToObject     {

public static T ConvertToObject<T>(DataRow row) where T : new()         {

System.Object obj = new T();

if (row != null)             {

DataTable dataTable = row.Table;

GetObject(dataTable.Columns, row, obj);

}

if (obj != null && obj is T)             {

return (T)obj;

}

else             {

return default(T);

}

}

private static void GetObject(DataColumnCollection cols, DataRow dr, System.Object obj)

{             Type type = obj.GetType();

PropertyInfo[] pros = type.GetProperties();

foreach (PropertyInfo pro in pros)             {

if (cols.Contains(pro.Name))

{

if ((pro.PropertyType).Name.ToLower() == "string")

pro.SetValue(obj, dr[pro.Name] == DBNull.Value ? "" : dr[pro.Name].ToString(), null);

else

pro.SetValue(obj, dr[pro.Name] == DBNull.Value ? null : dr[pro.Name], null);

}

}

}

public static List<T> ConvertToList<T>(DataTable dataTable) where T : new()

{       List<T> list = new List<T>();

foreach (DataRow row in dataTable.Rows)             {

T obj = ConvertToObject<T>(row);

list.Add(obj);             }

return list;

}

}

(4) 部分运行截图:

从数据库中导出excel报表的更多相关文章

  1. 从oracle数据库中导出excel问题导致乱码的问题

    使用plsqldev工具将oracle的查询结果导出为excel,结果可以成功导出,但是使用libreoffice进行查看时,有好多记录都是空的. 使用python进行导出(openpyxl模块进行e ...

  2. 用BCP从SQL Server 数据库中导出Excel文件

    BCP(Bulk Copy Program)是一种简单高效的数据传输方式在SQL Server中,其他数据传输方式还有SSIS和DTS. 这个程序的主要功能是从数据库中查询Job中指定step的执行信 ...

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

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

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

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

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

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

  6. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

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

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

  8. java导出excel报表

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

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

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

随机推荐

  1. 黑马-----内存模型和volatile详解

    黑马程序员:Java培训.Android培训.iOS培训..Net培训 JAVA线程-内存模型和volatile详解 一.单核内存模型 1.程序运行时,将临时数据存放到Cache中 2.将CPU计算所 ...

  2. c#中方法的重载

    转自:http://www.cnblogs.com/lovesong_blog/articles/1416617.html string和program都是Object的派生类,string类型是se ...

  3. css3-实现3D立方体旋转

    核心内容: 1.CSS3 中 animation.perspective 属性的熟练运用. 2.CSS3 中的变形属性 transform,在 3D 立体效果中的运用. 3.3D 立方体旋转实现原理. ...

  4. matlab小段代码学习

    matlab读hdf文件到txt filename='E:\data\H1BDLD10110607231863921.L2B.HDF'; h=hdftool(filename); Latitude = ...

  5. Hive自定义函数的学习笔记(1)

    前言: hive本身提供了丰富的函数集, 有普通函数(求平方sqrt), 聚合函数(求和sum), 以及表生成函数(explode, json_tuple)等等. 但不是所有的业务需求都能涉及和覆盖到 ...

  6. angular使用echarts折线图

    echarts是开源的画图工具,在angular框架中引入echarts不能直接使用.需要新建一个directive //echarts基本参数 app.factory('$echartsConfig ...

  7. 运用CADisplayLink来开启定时器

    CADisplayLink来开启定时器 CADisplayLink是以屏幕刷新频率将内容绘制到屏幕上的定时器,每秒60Hz.使用的时候,先创建一个CADisplayLink对象,将其添加到一个RunL ...

  8. jquery与各种UI框架的导入要注意的地方

    前端的处理我们会使用easyUI,amazeUI,bootstrap等等框架,然而每个页面都要导入这些js   css 文件,所以我们将要导入的文件提取出来,写在一个页面上,每次只要倒入该页面就行,如 ...

  9. SQL Server系统存储过程

    1. execute sp_databases   查询当前所有数据库大致信息(名称,大小等) 2. exec sp_helpdb [Myschool] 返回数据库的所有详细信息(数据库大小,位置,文 ...

  10. 差分:IncDec Sequence 差分数组

    突然就提到了这个东西,为了不再出现和去年联赛看见二分没学二分痛拿二等第一的情况,就去学了一下,基础还是比较简单的-- 先看一个经典例题: 给定一个长度为n的数列{a1,a2...an},每次可以选择一 ...