DataTable导出到Excel的优化

28 篇文章 0 订阅

一、DataTable To Excel

 

  先定义一下:

 

 rivate Excel.Application excelApp= new Excel.ApplicationClass();//Application与ApplicationClass的区别我没有明白。

 

  private Excel.Workbook excelBook = excelApp.Workbooks.Add(Type.Missing);

 

  private Excel.Worksheet excelSheet = (Excel.Worksheet)excelBook.ActiveSheet;

 

  excelApp.Visible = true;

 

  1、让我们看看在网上流传最多的解决方案:

 

  public void DataTableToExcel(DataTable dt)

 

  {

 

  for (int i = 0; i <dt.Rows.Count; i++)

 

  {

 

  for (int j=0;j<dt.Columns.Count;j++)

 

  {

 

  excelSheet.Cells[i+1,j+1] = dt.Rows[i][j].ToString();

 

  }

 

  }

 

  }

 

  不可否认这段程序会不出错误的运行,但是效率就比较低了,会随着数据行和列的增加而增加,主要的时间都耗在了Excel单元格的读取上。

 

  让我们改进一下,利用DataRow.ItemArray:

 

  public void DataTableToExcel(DataTable dt)

 

  {

 

  int colCount = dt.Columns.Count;

 

  for (int i = 0; i <dt.Rows.Count; i++)

 

  {

 

  excelSheet.get_Range(excelSheet.Cells[i+1,1], excelSheet.Cells[i+1, colCount])。Value2 = dt.Rows[i].ItemArray;

 

  }

 

  以上效率的损失主要是每导出一条记录都要与Excel交互一次,如果我们把数据准备好一次性写入Excel是否效率更快?看如下程序:

 

  public void DataTableToExcel(DataTable dt)

 

  {

 

  int rowCount = dt.Rows.Count;

 

  int colCount = dt.Columns.Count;

 

  object[,] dataArray = new object[rowCount,colCount];

 

  for (int i = 0; i <rowCount; i++)

 

  {

 

  for (int j=0;j<colCount;j++)

 

  {

 

  dataArray[i, j] = dt.Rows[i][j];

 

  }

 

  }

 

  excelSheet.get_Range("A1",excelSheet.Cells[rowCount,colCount]).Value2 = dataArray;

 

  }

 

  由于二维数组是在内存中实现,所以速度很快,由于是一次性写入到Excel中,使我们几乎感觉不到延迟,在Excel打开后数据马上就出来了,感觉很爽。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值