将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();
   }
 } 

相关文章推荐

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

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

SQL SERVER 与ACCESS、EXCEL的数据转换

刚来公司就有这样的需求了。熟悉SQL SERVER 2000的数据库管理员都知道,其DTS可以进行数据的导入导出,其实,我们也可以使用Transact-SQL语句进行导入导出操作。在Transact-...

SQL SERVER 与ACCESS、EXCEL的数据转换

SQL SERVER 与ACCESS、EXCEL的数据转换 熟悉SQL SERVER 2000的数据库管理员都知道,其DTS可以进行数据的导入导出,其实,我们也可以使用Transact-SQL语句进行...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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