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

转载 2007年10月08日 08:52:00
  /// <summary>
  /// 把指定的DataSet中的内容导出到Excel中.
  /// </summary>
  /// <param name="ds">ds参数为DateSet对象</param>
  /// <param name="ImpStr">该字符串用来指定一些字段来导出,其使用格式为:aaa|AAA,bbb|BBB   小写字符串为在Excel表中显示该字段的列标题,大写表示字段名.不同字段使用逗号分隔.</param>
  /// <param name="locR">数据导出到Excel中的开始行</param>
  /// <param name="locC">数据导出到Excel中的开始列</param>
  /// <param name="TitleStr">该字符串用来指定要导出的表和表的标题其格式为:aaa|AAA,bbb|BBB   小写为该表中显示的标题,大写为表名称.不同表使用逗号分隔</param>
  /// <param name="TilteLocR">显示标题的行</param>
  /// <param name="TitleLocC">显示标题的列</param>
  /// <param name="ColTitleColorIndex">列标题颜色索引</param>
  /// <example>Import2Excel(this.dsData ,"用户名|USERNAME,登录名|LOGINNAME",3,1,"用户名列表|BILL_USER",1,2 ,12);</example>
  private void Import2Excel(System.Data.DataSet ds,string ImpStr ,int locR,int locC,string TitleStr,int TilteLocR, int TitleLocC,int ColTitleColorIndex )
  {
   //加载Excel
   Microsoft.Office.Interop.Excel.ApplicationClass ex=new Microsoft.Office.Interop.Excel.ApplicationClass();
   ex.Visible=true ;//显示Excel
   if (ex==null)
   {
    //无法显示时报错
   MessageBox.Show("无法启动 Microsoft Office Excel,导出失败!","Import2Excel", MessageBoxButtons.OK,MessageBoxIcon.Stop );
   return ;
   }
   string[] tles=TitleStr.Split(",".ToCharArray());
   string[] Imps=ImpStr.Split(",".ToCharArray()) ;
   string[] tlbs=TitleStr.Split(",".ToCharArray ());
   //获得工作薄
       Microsoft.Office.Interop.Excel.Workbooks   wbs =ex.Workbooks;
   Microsoft.Office.Interop.Excel.Workbook wb= wbs.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
  

   int z=0;//Sheet索引
   foreach (string tblname in tlbs)
   {
    z+=1;
    //得到表和工作表一个工作表对应一个表,
    string[] tbn=tblname.Split("|".ToCharArray());
    System.Data.DataTable dt=ds.Tables[tbn[1].ToUpper() ];
    Microsoft.Office.Interop.Excel.Worksheet ws=
     (Microsoft.Office.Interop.Excel.Worksheet)wb.Worksheets[z];
    //工作表的第一行标题设置为该表的表名.
    //从格式字符串中去表名对应的名称.
//    int tm1=TitleStr.ToUpper().IndexOf(dt.TableName+"|")+dt.TableName.Length +1;
//    string tit=TitleStr.Substring(tm1,TitleStr.IndexOf(",",tm1)-tm1);
    ws.Cells[TilteLocR, TitleLocC]=tbn[0] ;//设置该单元格显示的标题
    ws.Name=dt.TableName ;//设置该Sheet的名称为表名.
    int n1=locC;
    //设置字段名称
    foreach (string imp in Imps)
     {
     string[] im=imp.Split("|".ToCharArray());
      n1+=1 ;
      ws.Cells[locR,  n1]=im[0];//'字段名称
      Microsoft.Office.Interop.Excel.Range rg=
           (Microsoft.Office.Interop.Excel.Range)ws.Cells[locR, n1];
      rg.Interior.ColorIndex=ColTitleColorIndex;
      rg.Font.Bold=true;
     }
    for (int y=0;y<=dt.Rows.Count -1;y+=1)
    {
    System.Data.DataRow dr=dt.Rows[y];
     int n2=1;
     foreach (string imp in Imps)
     {
     string[] im=imp.Split("|".ToCharArray());
     ws.Cells[locR+1+y,locC+n2]=dr[im[1].ToUpper()];
     n2+=1;  
     }
    }
   }
  } 

将 GridView、DataTable,DataSet 中的内容导出到 Excel 中多个工作表(Sheet) 的方法

该方法服务器端可以不用安装EXCEL。 Excel 可以保存成 xml 格式,并且支持Sheet功能,因此,我们就可以利用这个功能将 Gridview 导出到多个 Sheet  中去。而且可以很好地...
  • Trassion
  • Trassion
  • 2012年02月20日 11:37
  • 2304

DataSet导出到Excel,并生成文件(C#实现,可合并行和列)

using System; using System.IO; using System.Data; using System.Reflection; using System.Diagnost...
  • xujunheng
  • xujunheng
  • 2014年09月09日 19:06
  • 993

DataSet导出到Excel比较完整的解决方案(一)--客户端生成文件(downmoon)

有一客户需求:1、要从SQL Server数据库导出并生成Excel ;2、用户下载对应的Excel并填写上传再导入到SQL server。 费了将近六个小时,故一定要把过程写下来,希望看到此文的朋友...
  • downmoon
  • downmoon
  • 2009年01月16日 15:46
  • 13038

将DataSet中的数据导出到Excel表中

    实例代码:    ///     /// 导出Excel数据    ///     ///     ///     ///     public void CreateExcel(DataSe...
  • gooddasenlin
  • gooddasenlin
  • 2007年07月20日 11:11
  • 730

关于导出excel 把一个dataset的多个datatable导入到一个excel的多个sheet中

几经查询资料,我完成了这个看似结果还不错的任务,在解决任务的过程也也遇到了很多的问题,但最后胜利的成果还是要和大家分享一下,大家看看有没有什么问题,多提提意见,有更好的可以给我看看,我需要。代码如下u...
  • cdsnaspnet
  • cdsnaspnet
  • 2010年05月20日 19:35
  • 2437

asp.net Dataset导出excel

这种比前一种更好,此方法可以直接将数据库表导出到excel ,并不上绑定在某控件的数据表导出后还带有链接等后台的处理格外垃圾,故本人比较推荐使用此方法,希望大家可以借鉴借鉴             ...
  • a771948524
  • a771948524
  • 2013年05月09日 17:36
  • 1217

在ASP.NET中将dataset数据保存到excel,GridView导出到excel

1 把dataset数据保存到excel  protected void Page_Load(object sender, EventArgs e)    {        //建立连接       ...
  • highplayer
  • highplayer
  • 2010年06月10日 19:21
  • 3021

C#利用NOPI导出到Excel

想说点什么,但是那句话,不好说
  • wangjinlong_
  • wangjinlong_
  • 2017年07月31日 21:13
  • 390

js把html中的table数据导出到Excel中

//导出通用方法,在onlick事件中调用getImport(table名称)即可   var idTmr; function getExplorer() {     var explorer = w...
  • qq_34313263
  • qq_34313263
  • 2017年05月08日 14:11
  • 2549

C#中数据库数据如何导出至Excel表格

C#中数据库数据如何导出至Excel表格 标签: excel数据库c#insertstringnull 2011-12-13 16:21 17693人阅读 评论(9) 收藏 举报 ...
  • kasama1953
  • kasama1953
  • 2016年06月16日 23:28
  • 4681
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:把指定的DataSet中的内容导出到Excel中
举报原因:
原因补充:

(最多只允许输入30个字)