zoukankan      html  css  js  c++  java
  • ASP.NET导出EXCEL类

    最新ASP.NET导出EXCEL类

    说明:可以导出ASP.NET页面和DATAGRID(WebControl)数据,可以导出表单头

    using System;
    using System.Data;
    using System.Text;
    using System.Web;
    using System.Web.UI;
    using System.Diagnostics;
    using System.Web.UI.WebControls;
    using System.Web.UI.HtmlControls;
    using System.Data.SqlClient;
    using System.Collections;

    namespace bookstore
    {
     ///
     /// Excel 的摘要说明。
     ///
     public class Excel
     {
      public Excel()
      {
       //
       // TODO: 在此处添加构造函数逻辑
       //
      }
     

      public void SaveToExcel(Page myPage, DataTable dt,DataGrid DG,string myExcelHeader,HtmlTable Tab,string myFileName)
      {
       HttpResponse resp;   
       resp=myPage.Response;
       resp.ContentEncoding=Encoding.GetEncoding("GB18030");
       resp.AppendHeader("Content-Disposition","attachment;filename="+myFileName+".xls");
       resp.ContentType="application/ms-excel";

       string colHeaders = " "+ myExcelHeader +" ";

       colHeaders+=tableHeader(Tab)+" ";

       StringBuilder sb=new StringBuilder();
      
       int mycol=DG.Columns.Count;
       ArrayList myAL=new ArrayList();

       for(int i=0;i   {
        colHeaders +=DG.Columns[i].HeaderText+" "; 
        myAL.Add(((System.Web.UI.WebControls.BoundColumn)(DG.Columns[i])).DataField); 
       }
       colHeaders += " ";
       sb.Append(colHeaders);

       int myrow=dt.Rows.Count;

       for(int k=0;k   {
        foreach(string field in myAL)
        {  
         sb.Append(dt.Rows[k][field]);
         sb.Append(" ");
        }
        sb.Append(" ");
       }      
      
       colHeaders=sb.ToString();

       colHeaders=colHeaders+" ";
       resp.Write(colHeaders); 

       resp.End();
       resp.Clear();
       resp.Close(); 
      }


      /*得到表单头子*/
      /*表单头子有TABLE组成,偶次项排列,TABLE在HTML中加 RUNAT=SERVER*/
      public string tableHeader(HtmlTable Tab)
      {
       int iCols=Tab.Rows[0].Cells.Count;
       int iRows=Tab.Rows.Count;
       string str="";
      
       for(int row=0;row   {
        for(int col=0;col    {
         if(col%2==1)//取偶次项的控件数据(目前只有TextBox和DropDownList,没有包含LABEL)
         {
          try
          {
           if(Tab.Rows[row].Cells[col].Controls[0].ToString()=="System.Web.UI.LiteralControl")
           {
            if(Tab.Rows[row].Cells[col].Controls[1].ToString()=="System.Web.UI.WebControls.TextBox")
            {
             str+=((System.Web.UI.WebControls.TextBox)(Tab.Rows[row].Cells[col].Controls[1])).Text+" ";
            }
            if(Tab.Rows[row].Cells[col].Controls[1].ToString()=="System.Web.UI.WebControls.DropDownList")
            {
             str+=((System.Web.UI.WebControls.ListControl)(((System.Web.UI.WebControls.DropDownList)((Tab.Rows[row].Cells[col].Controls[1]))))).SelectedValue+" ";    
            }
           }
           else
           {
            if(Tab.Rows[row].Cells[col].Controls[0].ToString()=="System.Web.UI.WebControls.TextBox")
            {
             str+=((System.Web.UI.WebControls.TextBox)(Tab.Rows[row].Cells[col].Controls[0])).Text+" ";
            }
            if(Tab.Rows[row].Cells[col].Controls[0].ToString()=="System.Web.UI.WebControls.DropDownList")
            {
             str+=((System.Web.UI.WebControls.ListControl)(((System.Web.UI.WebControls.DropDownList)((Tab.Rows[row].Cells[col].Controls[0]))))).SelectedValue+" ";    
            }
           }
          }
          catch
          {
           str+=Tab.Rows[row].Cells[col].InnerHtml+" ";
          }
          if((col+1)%iCols==0)
          {
           str+=" ";
          }
         }
         else
         {
          str+=" "+Tab.Rows[row].Cells[col].InnerHtml+" ";
         }
        }
       }
       return(str);
      }
     
     }

    佛为心,道为骨,儒为表,大度看世界; 技在手,能在身,思在脑,从容过生活; 三千年读史,不外功名利禄; 九万里悟道,终归诗酒田园;
  • 相关阅读:
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp 8 Web基础
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp7 网络欺诈防范
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp6 MSF基础应用
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp5 信息搜集与漏洞扫描
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp4 恶意代码分析
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp3 免杀原理与实践
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp2 后门原理与实践
    # 2019-2020-2 网络对抗技术 20175333 曹雅坤 Exp1 PC平台逆向破解
    2019-2020-1 20175312 20175333 实验五 通讯协议设计
    2019-2020-2 20175320 《网络对抗技术》免考实践报告 手工实现对PE文件的shellcode注入
  • 原文地址:https://www.cnblogs.com/taofx/p/4137242.html
Copyright © 2011-2022 走看看