把WebForm数据导出到Excel中

excel|web|数据

上午给系统的订单管理部分添加了一个功能,把查询到的订单信息导出到Excel,供管理员分析用。以前写的代码如下:

Response.Clear();
Response.BufferOutput = true;
Response.Charset = "GB2312";
Response.AppendHeader("Content-Disposition","attachment;filename = FileName.xls");
Response.ContentEncoding = Encoding.GetEncoding("GB2312");
Response.ContentType = "application/ms-excel";
this.EnableViewState = false;
System.Globalization.CultureInfo myinfo = new System.Globalization.CultureInfo("ZH-CN", true);
StringWriter osw = new StringWriter(myinfo);
HtmlTextWriter ohtw = new HtmlTextWriter(osw);
dgQueryResult.RenderControl(ohtw);
Response.Write(osw);
Response.End(); 
        我的查询用了分页,客户要求把所有查询到的数据都导出到Excel,所以不能象以前那样通过把控件的内容导出到Excel来实现此功能,于是把代码改成这样:
   Response.Clear();
Response.BufferOutput = true;
Response.Charset = "GB2312";
Response.AppendHeader("Content-Disposition","attachment;filename = 订单.xls");
Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
Response.ContentType = "application/ms-excel";
string strExcelHeader = string.Empty;
string strExcelItems;
if(ViewState["SQL"] != null)    // 取前面查询用的SQL语句
{
     // 取得各列标题,各标题之间以\t分割,最后一个列标题后加回车符 
     strExcelHeader = "订单号\t经销商\t地区\t小类\t商品\t实付金额\t下单时间\t有效状态\t处理状态\t\n";                                     
    // 向HTTP输出流中写入取得的数据信息 
    Response.Write(strExcelHeader);   
         
    // 逐行处理查询结果数据 
    ITDBHandle itDbHandle = new ITDBHandle();
    itDbHandle.QueryString = ViewState["SQL"].ToString();
    SqlDataReader reader = itDbHandle.ExecuteDataReader();      
    while(reader.Read()) 
    { 
        strExcelItems = string.Empty;
        strExcelItems += reader["OrderID"].ToString() + "\t";   
        strExcelItems += reader["DealerName"].ToString() + "\t";
        strExcelItems += reader["City"].ToString() + "\t";
        strExcelItems += reader["SmallClassName"].ToString() + "\t";
        strExcelItems += reader["BrandName"].ToString() + reader["Model"].ToString() + "\t";
        strExcelItems += reader["TotalPrice"].ToString() + "\t";
        strExcelItems += reader["OrderDate"].ToString() + "\t";
        strExcelItems += reader["IsValid"].ToString() + "\t";
        strExcelItems += reader["DealState"].ToString()  +"\n";                                                  
        Response.Write(strExcelItems); 
   } 
    reader.Close();
    Response.End();
}   
       我这里只是简单的把查询到的数据以Excel的形式Write出来(当然也可以是其他格式,比如XML),对简单的需求足矣了,当然,用.NET直接去操作Excel文件也是很简单的,有很多这样的例子可以参考。

时间: 2024-10-03 12:20:18

把WebForm数据导出到Excel中的相关文章

C#将DateTable表数据导出到Excel中

问题描述 在VisualC#中调用Excel表格,并不像读取Excel表格中的数据那么容易了,因为在VisualC#中调用Excel表格要使用到Excel的COM组件.以VS2005为例,首先添加引用--在COM选项中,添加MicrosfotExcel11.0ObjetLibrary. 然后在程序中引入命名空间,UsingMicrosoft.Office.Interop.Excel; 以下面几条语句来介绍一个Excel类中的几个对象. //实例化一个Excel应用程序对象Microsoft.Of

小弟请教如何将webcontrols.table的数据导出到excel中

问题描述 求代码 解决方案 解决方案二:参考:自己改一下,应该就行了.

机房收费系统——VB将MSHflexgrid控件中的数据导出为Excel

            在做机房收费系统的时候,许多窗体用到的一个功能,就是将从数据库中提取出来的数据导出到Excel中.   首先,引用Microsoft Excel 14.0 Object Library   然后,写代码     Public Sub OutDataToExcel(Flex As MSHFlexGrid) '导出至Excel Dim i As Integer Dim j As Integer Dim Line As Integer Dim outExcel As Excel

asp中把数据导出为excel的2种方法_ASP编程

我们在做项目的时候经常要将数据库的数据导出到excel中,很多asp用户并不知道怎么写. 这里明凯总结了两种方法来导出excel,希望能帮到大家. 方法一:用excel组件 < % set rs=server.createobject("adodb.recordset") sql="select * from mkusers" rs.open sql,objconn,1,1 Set ExcelApp =CreateObject("Excel.Appl

asp中把数据导出为excel的2种方法

我们在做项目的时候经常要将数据库的数据导出到excel中,很多asp用户并不知道怎么写. 这里明凯总结了两种方法来导出excel,希望能帮到大家. 方法一:用excel组件 < % set rs=server.createobject("adodb.recordset") sql="select * from mkusers" rs.open sql,objconn,1,1 Set ExcelApp =CreateObject("Excel.Appl

c#树形数据导出到excel,急切,在线等。

问题描述 数据表是这样存的.怎么实现把数据库数据导出到excel中,能自动生成如下表头.这个表头如何生成啊. 解决方案 本帖最后由 7259 于 2015-11-26 17:46:32 编辑解决方案二:有多少个末节点(没有子节点)就有多少列树的深度就是行数root节点在第一行父节点根据末节点合并单元格解决方案三:NPOI按照你给的Excel格式能操作生成然后单元格的数据就要看你表的结构去读进去了解决方案四:没有自动,要什么样的表头,也要你自己去填充,用微软的dll或者NPOI都可以或者自己先设计

把指定的DataSet中的内容导出到Excel中

  /// <summary>  /// 把指定的DataSet中的内容导出到Excel中.  /// </summary>  /// <param name="ds">ds参数为DateSet对象</param>  /// <param name="ImpStr">该字符串用来指定一些字段来导出,其使用格式为:aaa|AAA,bbb|BBB   小写字符串为在Excel表中显示该字段的列标题,大写表示字段

机房收费系统的实现:VB中如何将MSHFlexGrid控件中的数据导出到Excel

机房收费系统中,好多查询的窗体都包含同一个功能:将数据库中查询到的数据显示在MSHFlexGrid控件中,然后再把MSHFlexGrid控件中的数据导出到Excel表格中. 虽然之前做过学生信息管理系统,不过并没有涉及到这个功能,因此记录于此,于己,回顾反思,于大家,分享学习. 方法一:在根目录中事先建立空的Excel表格 1.在与VB工程同一根目录中建立将要导入数据的Excel表格: 2.在VB事件中写代码: Private Sub cmdExport_Click() Dim i As Int

datagridview-C#的dategridview中数据导出到excel的问题

问题描述 C#的dategridview中数据导出到excel的问题 public bool ExportDataGridview(DataGridView gridView, bool isShowExcle) { if (gridView.Rows.Count == 0) { MessageBox.Show("请您检查是否有数据导出","提示",MessageBoxButtons.OK,MessageBoxIcon.Information); return fa