从数据库中导出excel报表

通常需要将后台数据库中的数据集或者是其他列表等导出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) 部分运行截图:

时间: 2024-12-21 17:26:34

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

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

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

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

在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅仅简单的读取office中的数据.尤其是在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.而数据导出的格式一般是EXCEL或者PDF .所以今天我们来简单看一下利用Apache  POI实现数据库中数据导出excel报表.在java中有很多实现数据导出excel报表的第三方jar包.但在比较了一下感觉还是POI相对来

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

效果图: controller层方法: /**     *      * 导出Excel报表     * @param request     * @return     *      */    @RequestMapping("/export")    @ResponseBody    public void export(HttpServletRequest request,            HttpServletResponse response, String year

java导出excel报表

1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;import java.util.Map;import javax.servlet.http.HttpServletResponse;import jxl.Workbook;import jxl.format.Alignment;import jxl.format.Border;import jxl.for

PHP从数据库原生导出Excel文件

<?php //这里三个header文件是为了将数据库数据导出Excel表格中,必须存在;//设置编码header('Content-type: text/html; charset=utf-8');//设置为Excelheader("Content-type:application/vnd.ms-excel");//设置Excel表名header("Content-Disposition:filename=PHP_est.xls"); //面向过程风格,连接

在ASP程序中打印Excel报表的新方法

目前,B/S模式(浏览器/服务器模式)成为企业网上首选的计算模式.由于B/S模式的特殊性,在C/S下相对较易实现的Excel报表打印功能在B/S下却成为一个难点.本人通过研究写了一个基于ASP程序的打印Excel报表的程序.本程序的特点是无须任何组件. Print.asp ------------------------------------------------ <html><title>打印Excel报表</title> <% '控制脚本语言 respon

Asp.net中导出Excel文档(Gridview)

主要思路,通过GridView来导出文档. 新建一个Aspx页面,页面创建GridView控件,后台绑定好数据源.然后load中直接打印即可导出 前台的GridView <asp:GridView ID="GridView1" BorderColor="Black" runat="server" AutoGenerateColumns="False" Font-Size="12px" Width=&q

ASP.net中导出Excel的简单方法介绍

下面介绍一种ASP.net中导出Excel的简单方法 先上代码:前台代码如下(这是自己项目里面写的一点代码先贴出来吧) <div id="export" runat="server" style="width: 700px; margin-left: auto; margin-right: auto;"> <!--startprint--> <table width="100%" border=&

Java实现POI导出Excel报表功能

在公司的很多业务中需要做成报表的形式,在市场有很多开源的Java框架,例如POI.JXL等,下面我们结合SpringMVC框架,来实现报表导出功能 首先在项目的lib目录下面加入poi-3.7.jar 核心工具类: import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputSt