将DataGrid中的数据转换为Excel(c#)

转载 2007年10月04日 08:34:00

public void gSendGridInfoToExcel(DataGrid GridX)
  {
   
   Excel.Application excel= new Excel.ApplicationClass();
   Excel._Workbook xBk = excel.Workbooks.Add(true);
   Excel._Worksheet xSt = (Excel._Worksheet)xBk.ActiveSheet;
   Excel.Range excelCell=null;
   try
   {
    //赋值对象
    object[] objarr;
    DataTable dtTest=new DataTable();
    int i,j;
    int iRows,iCows;
    int iVisable;
    iVisable=0;
    iCows=0;
    ArrayList list=new ArrayList();
    //如果绑定数据源是DataTable和DataSet,取得行数
    if (GridX.DataSource is  System.Data.DataSet || GridX.DataSource is System.Data.DataTable)
    {
     dtTest=(DataTable)GridX.DataSource;
     iRows=dtTest.Rows.Count;
    }
    else if (GridX.DataSource is System.Data.DataView)
    {
     DataView dvTest=(DataView)GridX.DataSource;
     iRows=dvTest.Count;
     dtTest=dvTest.Table;
    }
     //如果是集合取得行数
    else
    {
     System.Collections.CollectionBase ColTest;
     ColTest=(System.Collections.CollectionBase)GridX.DataSource;
     iRows=ColTest.Count;
    }
    //如果有TableStyles则根据TableStyles取得(标题行)


    if (GridX.TableStyles.Count>0)
    {
     iCows=GridX.TableStyles[0].GridColumnStyles.Count;
     for(i=0;i<iCows;i++)
     {
      if(GridX.TableStyles[0].GridColumnStyles[i].Width>0)
      {
       iVisable++;
       list.Add(GridX.TableStyles[0].GridColumnStyles[i].HeaderText);
      }
     }
     objarr = new object[iVisable];
     objarr=list.ToArray();
     excelCell = xSt.get_Range(excel.Cells[1,1],excel.Cells[1,iVisable]);
     excelCell.Value2 = objarr;
     //数据行
     for(i=0;i<iRows;i++)
     {
      objarr = new object[iVisable];
      list.Clear();

      for(j=0;j<iCows;j++)
      {
       if(GridX.TableStyles[0].GridColumnStyles[j].Width>0)
       {
        list.Add("'"+GridX[i,j].ToString().Replace("/n",""));
       }

      }
      if (list.Equals(System.DBNull.Value))
      {
       break;
      }
      objarr=list.ToArray();
      excelCell = xSt.get_Range(excel.Cells[i+2,1],excel.Cells[i+2,iVisable]);
      excelCell.Value2 = objarr;
     }
    }
    else
    {
     iCows=dtTest.Columns.Count;
     for(i=0;i<iCows;i++)
     {
      list.Add(dtTest.Columns[i].Caption);
     }
     objarr = new object[iCows];
     objarr=list.ToArray();
     excelCell = xSt.get_Range(excel.Cells[1,1],excel.Cells[1,iCows]);
     excelCell.Value2 = objarr;

     //数据行
     for(i=0;i<iRows;i++)
     {
      objarr = new object[iCows];
      list.Clear();

      for(j=0;j<iCows;j++)
      {
       list.Add("'"+GridX[i,j].ToString().Replace("/n",""));
      }
      if (list.Equals(System.DBNull.Value))
      {
       break;
      }
      objarr=list.ToArray();
      excelCell = xSt.get_Range(excel.Cells[i+2,1],excel.Cells[i+2,iCows]);
      excelCell.Value2 = objarr;
     }

    }
    dtTest.Dispose();

    excel.Visible=true;

   }
   catch (System.Exception e)
   {
    throw e;
   }
   finally
   {
    excelCell=null;
    xBk=null;
    xSt=null;
    excel=null;
    GC.Collect();
   }
 } 

C#用NOPI,上传EXCEL,并将数据转换成DataTable

更新时间:2017年3月28日 简介:正好这几天用到,也有ADO方式链接的,但有时候得安装相应环境又有03和07版区分,以及链接字符串不同,最后用NOPI方式获取EXCEL,实现后,整理后记录下来一个...

Excel_数据转换成Marc格式说明

  • 2013年09月03日 12:53
  • 5.7MB
  • 下载

Lua工具:Excel数据转换成Lua文件

现在很多手游使用Cocos2dx + Lua 的开发模式,在这过程中,很多游戏的基础数据,放在哪里,什么格式,怎么做效率最高。 当然是你已经采用的开发模式了,         基础数据做成Lua 文件...

excel表格数据转换成javaBean

  • 2012年05月24日 15:11
  • 28KB
  • 下载

EXCEL中的空间数据转换为shapefile和GDB中的feature class

在实际工作中,经常遇到需要将EXCEL格式的空间数据转换成shape格式的矢量图形数据文件,或者将其导入到GDB中的某个feature class中进行空间数据的入库工作。本文介绍如何通过使用ARCM...

SQL SERVER 与ACCESS、EXCEL的数据转换

data process SQL SERVER 与ACCESS、EXCEL的数据转换
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:将DataGrid中的数据转换为Excel(c#)
举报原因:
原因补充:

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