欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#導出Excel的示例詳解

 更新時間:2017年08月29日 11:53:42   作者:YellowCool  
這篇文章主要為大家詳細介紹了C#導出Excel的示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C#導出Excel的具體代碼,供大家參考,具體內容如下

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Windows.Forms;
using System.Reflection;

namespace DMS
{
/// <summary>
/// C#操作Excel類
/// </summary>
class ExcelOperate
{
//法一
//public bool DataSetToExcel(DataSet dataSet, bool isShowExcle)
//{
//  DataTable dataTable = dataSet.Tables[0];
//  int rowNumber = dataTable.Rows.Count;
//  int columnNumber = dataTable.Columns.Count;

//  if (rowNumber == 0)
//  {
//    MessageBox.Show("沒有任何數(shù)據(jù)可以導入到Excel文件!");
//    return false;
//  }

//  //建立Excel對象
//  Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//  excel.Application.Workbooks.Add(true);
//  excel.Visible = isShowExcle;//是否打開該Excel文件

//  //填充數(shù)據(jù)
//  for (int c = 0; c < rowNumber; c++)
//  {
//    for (int j = 0; j < columnNumber; j++)
//    {
//      excel.Cells[c + 1, j + 1] = dataTable.Rows[c].ItemArray[j];
//    }
//  }

//  return true;
//}


//法二
//public bool DataSetToExcel(DataSet dataSet, bool isShowExcle)
//{
//  DataTable dataTable = dataSet.Tables[0];
//  int rowNumber = dataTable.Rows.Count;

//  int rowIndex = 1;
//  int colIndex = 0;


//  if (rowNumber == 0)
//  {
//    return false;
//  }

//  //建立Excel對象
//  Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//  excel.Application.Workbooks.Add(true);
//  excel.Visible = isShowExcle;

//  //生成字段名稱
//  foreach (DataColumn col in dataTable.Columns)
//  {
//    colIndex++;
//    excel.Cells[1, colIndex] = col.ColumnName;
//  }

//  //填充數(shù)據(jù)
//  foreach (DataRow row in dataTable.Rows)
//  {
//    rowIndex++;
//    colIndex = 0;
//    foreach (DataColumn col in dataTable.Columns)
//    {
//      colIndex++;
//      excel.Cells[rowIndex, colIndex] = row[col.ColumnName];
//    }
//  }

//  return true;
//}

//法三(速度最快)
/// <summary>
/// 將數(shù)據(jù)集中的數(shù)據(jù)導出到EXCEL文件
/// </summary>
/// <param name="dataSet">輸入數(shù)據(jù)集</param>
/// <param name="isShowExcle">是否顯示該EXCEL文件</param>
/// <returns></returns>
public bool DataSetToExcel(DataSet dataSet, bool isShowExcle)
{
DataTable dataTable = dataSet.Tables[0];
int rowNumber = dataTable.Rows.Count;//不包括字段名
int columnNumber = dataTable.Columns.Count;
int colIndex = 0;

if (rowNumber == 0) 
{
return false;
}

//建立Excel對象 
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//excel.Application.Workbooks.Add(true);
Microsoft.Office.Interop.Excel.Workbook workbook = excel.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];
excel.Visible = isShowExcle;
//Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)excel.Worksheets[1];
Microsoft.Office.Interop.Excel.Range range;

//生成字段名稱 
foreach (DataColumn col in dataTable.Columns)
{
colIndex++;
excel.Cells[1, colIndex] = col.ColumnName;
}

object[,] objData = new object[rowNumber, columnNumber]; 

for (int r = 0; r < rowNumber; r++) 
{
for (int c = 0; c < columnNumber; c++)
{
objData[r, c] = dataTable.Rows[r][c];
}
//Application.DoEvents();
}

// 寫入Excel 
range = worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, columnNumber]);
//range.NumberFormat = "@";//設置單元格為文本格式
range.Value2 = objData;
worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, 1]).NumberFormat = "yyyy-m-d h:mm";

return true; 
}

//法四
//public bool DataSetToExcel(DataSet dataSet, bool isShowExcle)
//{
//  DataTable dataTable = dataSet.Tables[0];
//  int rowNumber = dataTable.Rows.Count;
//  int columnNumber = dataTable.Columns.Count;
//  String stringBuffer = "";

//  if (rowNumber == 0)
//  {
//    MessageBox.Show("沒有任何數(shù)據(jù)可以導入到Excel文件!");
//    return false;
//  }

//  //建立Excel對象
//  Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//  excel.Application.Workbooks.Add(true);
//  excel.Visible = isShowExcle;//是否打開該Excel文件

//  //填充數(shù)據(jù)
//  for (int i = 0; i < rowNumber; i++)
//  {
//    for (int j = 0; j < columnNumber; j++)
//    {
//      stringBuffer += dataTable.Rows[i].ItemArray[j].ToString();
//      if (j < columnNumber - 1)
//      {
//        stringBuffer += "\t";
//      }
//    }
//    stringBuffer += "\n";
//  }
//  Clipboard.Clear();
//  Clipboard.SetDataObject(stringBuffer);
//  ((Microsoft.Office.Interop.Excel.Range)excel.Cells[1, 1]).Select();
//  ((Microsoft.Office.Interop.Excel.Worksheet)excel.ActiveWorkbook.ActiveSheet).Paste(Missing.Value, Missing.Value);
//  Clipboard.Clear();

//  return true;
//}

//public bool DataSetToExcel(DataSet dataSet, string fileName, bool isShowExcle)
//{
//  DataTable dataTable = dataSet.Tables[0];
//  int rowNumber = dataTable.Rows.Count;
//  int columnNumber = dataTable.Columns.Count;

//  if (rowNumber == 0)
//  {
//    MessageBox.Show("沒有任何數(shù)據(jù)可以導入到Excel文件!");
//    return false;
//  }

//  //建立Excel對象
//  Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//  Microsoft.Office.Interop.Excel.Workbook workBook = excel.Application.Workbooks.Add(true);
//  excel.Visible = false;//是否打開該Excel文件

//  //填充數(shù)據(jù)
//  for (int i = 0; i < rowNumber; i++)
//  {
//    for (int j = 0; j < columnNumber; j++)
//    {
//      excel.Cells[i + 1, j + 1] = dataTable.Rows[i].ItemArray[j];
//    }
//  }

//  //string fileName = path + "\\" + DateTime.Now.ToString().Replace(':', '_') + ".xls";
//  workBook.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

//  try
//  {
//    workBook.Saved = true;
//    excel.UserControl = false;
//    //excelapp.Quit();
//  }
//  catch (Exception exception)
//  {
//    MessageBox.Show(exception.Message);
//  }
//  finally
//  {
//    workBook.Close(Microsoft.Office.Interop.Excel.XlSaveAction.xlSaveChanges, Missing.Value, Missing.Value);
//    excel.Quit();
//  }

//  if (isShowExcle)
//  {
//    System.Diagnostics.Process.Start(fileName);
//  }
//  return true;
//}

//public bool DataSetToExcel(DataSet dataSet, string fileName, bool isShowExcle)
//{
//  DataTable dataTable = dataSet.Tables[0];
//  int rowNumber = dataTable.Rows.Count;//不包括字段名
//  int columnNumber = dataTable.Columns.Count;
//  int colIndex = 0;

//  if (rowNumber == 0)
//  {
//    MessageBox.Show("沒有任何數(shù)據(jù)可以導入到Excel文件!");
//    return false;
//  }

//  //建立Excel對象
//  Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//  //excel.Application.Workbooks.Add(true);
//  Microsoft.Office.Interop.Excel.Workbook workbook = excel.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
//  Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];
//  excel.Visible = isShowExcle;
//  //Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)excel.Worksheets[1];
//  worksheet.Name = "撓度數(shù)據(jù)";
//  Microsoft.Office.Interop.Excel.Range range;

//  //生成字段名稱
//  foreach (DataColumn col in dataTable.Columns)
//  {
//    colIndex++;
//    excel.Cells[1, colIndex] = col.ColumnName;
//  }

//  object[,] objData = new object[rowNumber, columnNumber];

//  for (int r = 0; r < rowNumber; r++)
//  {
//    for (int c = 0; c < columnNumber; c++)
//    {
//      objData[r, c] = dataTable.Rows[r][c];
//    }
//    //Application.DoEvents();
//  }

//  // 寫入Excel
//  range = worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, columnNumber]);
//  //range.NumberFormat = "@";//設置單元格為文本格式
//  range.Value2 = objData;
//  worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, 1]).NumberFormat = "yyyy-m-d h:mm";

//  //string fileName = path + "\\" + DateTime.Now.ToString().Replace(':', '_') + ".xls";
//  workbook.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

//  try
//  {
//    workbook.Saved = true;
//    excel.UserControl = false;
//    //excelapp.Quit();
//  }
//  catch (Exception exception)
//  {
//    MessageBox.Show(exception.Message);
//  }
//  finally
//  {
//    workbook.Close(Microsoft.Office.Interop.Excel.XlSaveAction.xlSaveChanges, Missing.Value, Missing.Value);
//    excel.Quit();
//  }

//  //if (isShowExcle)
//  //{
//  //  System.Diagnostics.Process.Start(fileName);
//  //}
//  return true;
//}

/// <summary>
/// 將數(shù)據(jù)集中的數(shù)據(jù)保存到EXCEL文件
/// </summary>
/// <param name="dataSet">輸入數(shù)據(jù)集</param>
/// <param name="fileName">保存EXCEL文件的絕對路徑名</param>
/// <param name="isShowExcle">是否打開EXCEL文件</param>
/// <returns></returns>
public bool DataSetToExcel(DataSet dataSet, string fileName, bool isShowExcle)
{
DataTable dataTable = dataSet.Tables[0];
int rowNumber = dataTable.Rows.Count;//不包括字段名
int columnNumber = dataTable.Columns.Count;
int colIndex = 0;

if (rowNumber == 0) 
{
MessageBox.Show("沒有任何數(shù)據(jù)可以導入到Excel文件!");
return false;
}

//建立Excel對象 
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//excel.Application.Workbooks.Add(true);
Microsoft.Office.Interop.Excel.Workbook workbook = excel.Workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet);
Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1];
excel.Visible = false;
//Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)excel.Worksheets[1];
Microsoft.Office.Interop.Excel.Range range;

//生成字段名稱 
foreach (DataColumn col in dataTable.Columns)
{
colIndex++;
excel.Cells[1, colIndex] = col.ColumnName;
}

object[,] objData = new object[rowNumber, columnNumber]; 

for (int r = 0; r < rowNumber; r++) 
{
for (int c = 0; c < columnNumber; c++)
{
objData[r, c] = dataTable.Rows[r][c];
}
//Application.DoEvents();
}

// 寫入Excel 
range = worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, columnNumber]);
//range.NumberFormat = "@";//設置單元格為文本格式
range.Value2 = objData;
worksheet.get_Range(excel.Cells[2, 1], excel.Cells[rowNumber + 1, 1]).NumberFormat = "yyyy-m-d h:mm";

//string fileName = path + "\\" + DateTime.Now.ToString().Replace(':', '_') + ".xls"; 
workbook.SaveAs(fileName, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value, Missing.Value, Missing.Value, Missing.Value);

try 
{
workbook.Saved = true;
excel.UserControl = false;
//excelapp.Quit();
}
catch (Exception exception)
{
MessageBox.Show(exception.Message);
}
finally
{
workbook.Close(Microsoft.Office.Interop.Excel.XlSaveAction.xlSaveChanges, Missing.Value, Missing.Value);
excel.Quit();
}

if (isShowExcle) 
{
System.Diagnostics.Process.Start(fileName);
}
return true;
}
}
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C#常用自定義函數(shù)小結

    C#常用自定義函數(shù)小結

    這篇文章主要介紹了C#常用自定義函數(shù),包括將數(shù)組轉成字符串、DateTime時間格式轉換為Unix時間戳格式和生成某個范圍內的隨機數(shù),需要的朋友可以參考下
    2014-09-09
  • SQL語句刪除和添加外鍵、主鍵的方法

    SQL語句刪除和添加外鍵、主鍵的方法

    本文將詳細介紹SQL語句刪除和添加外鍵、主鍵的方法,需要的朋友可以參考下
    2012-11-11
  • Unity接入高德開放API實現(xiàn)IP定位

    Unity接入高德開放API實現(xiàn)IP定位

    這篇文章主要為大家介紹了Unity如何接入高德開放API實現(xiàn)IP定位功能,文中的示例代碼講解詳細,對我們學習或工作有一定參考價值,需要的可以參考一下
    2022-04-04
  • C#中實現(xiàn)深度優(yōu)先搜索

    C#中實現(xiàn)深度優(yōu)先搜索

    深度優(yōu)先搜索(DFS)是一種遍歷或搜索圖或樹的算法,廣泛應用于迷宮尋路、圖像處理、路徑規(guī)劃、模式識別、社交網(wǎng)絡分析等領域,學習DFS有助于理解圖結構,解決回溯問題,提升算法設計與分析能力,下面就來介紹一下
    2024-10-10
  • 解析使用C# lock同時訪問共享數(shù)據(jù)

    解析使用C# lock同時訪問共享數(shù)據(jù)

    本篇文章是對使用C# lock同時訪問共享數(shù)據(jù)進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • C#使用游標實現(xiàn)補間函數(shù)

    C#使用游標實現(xiàn)補間函數(shù)

    這篇文章主要為大家詳細介紹了C#使用游標實現(xiàn)補間函數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • asp.net core 使用 tensorflowjs實現(xiàn) face recognition的源代碼

    asp.net core 使用 tensorflowjs實現(xiàn) face recognition的源代碼

    tensorflowjs,在該項目中使用了ml5js這個封裝過的機器學習JavaScript類庫, 使用起來更簡單,本文給大家分享asp.net core 使用 tensorflowjs實現(xiàn) face recognition的源代碼,需要的朋友參考下吧
    2021-06-06
  • C#多線程Thread使用示例詳解

    C#多線程Thread使用示例詳解

    這篇文章主要為大家詳細介紹了C#多線程Thread使用示例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • Unity實現(xiàn)圓形Image組件

    Unity實現(xiàn)圓形Image組件

    這篇文章主要為大家詳細介紹了Unity實現(xiàn)圓形Image組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • 如何用C#創(chuàng)建用戶自定義異常淺析

    如何用C#創(chuàng)建用戶自定義異常淺析

    雖然在 C# 語言中已經(jīng)提供了很多異常處理類,但在實際編程中還是會遇到未涉及的一些異常處理,這篇文章主要給大家介紹了關于如何用C#創(chuàng)建用戶自定義異常的相關資料,需要的朋友可以參考下
    2021-06-06

最新評論