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("没有任何数据可以导入到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文件

//    //填充数据 
//    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; 
//    }

//    //填充数据 
//    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> 
/// 将数据集中的数据导出到EXCEL文件 
/// </summary> 
/// <param name="dataSet">输入数据集</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("没有任何数据可以导入到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文件

//    //填充数据 
//    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("没有任何数据可以导入到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文件

//    //填充数据 
//    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("没有任何数据可以导入到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 = "挠度数据"; 
//    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> 
/// 将数据集中的数据保存到EXCEL文件 
/// </summary> 
/// <param name="dataSet">输入数据集</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("没有任何数据可以导入到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#将数据集DataSet中的数据导出到EXCEL文件的几种方法的更多相关文章

  1. Datagrid数据导出到excel文件的三种方法

    原文连接: http://www.cnblogs.com/xieduo/articles/606202.html 一.文件保存在服务器,提供下载 方法一:导出到csv文件,存放在服务器端任一路径,然后 ...

  2. Qt中将QTableView中的数据导出为Excel文件

    如果你在做一个报表类的程序,可能将内容导出为Excel文件是一项必须的功能.之前使用MFC的时候我就写过一个类,用于将grid中的数据导出为Excel文件.在使用了QtSql模块后,我很容易的将这个类 ...

  3. C#中dategridview数据导出为excel文件

    先从数据库中获取数据,绑定在datagridview中,再从dategridview中导出为excel文件 1.新建窗体,把控件datagridview和按钮设置好,如图

  4. html5中 table数据导出到excel文件

    JS代码: /** * table数据导出到excel * 形参 table : tableId ; * sheetName : 工作薄名 * fileName : 文件名 * linkId :隐藏的 ...

  5. mysql导出csv/excel文件的几种方法,mysql的load导入csv数据

    方法一 php教程用mysql的命令和shell select * into outfile './bestlovesky.xls' from bestlovesky where 1 order by ...

  6. 机房收费系统——在VB中将MSHFlexGrid控件中的数据导出到Excel

    机房收费系统中,好多查询的窗体都包含同一个功能:将数据库中查询到的数据显示在MSHFlexGrid控件中,然后再把MSHFlexGrid控件中的数据导出到Excel表格中. 虽然之前做过学生信息管理系 ...

  7. 将Datagridview中的数据导出至Excel中

        首先添加一个模块ImportToExcel,并添加引用         然后导入命名空间: Imports Microsoft.Office.Interop Imports System.Da ...

  8. Asp.net网页中DataGridView数据导出到Excel

    经过上网找资料,终于找到一种可以直接将GridView中数据导出到Excel文件的方法,归纳方法如下: 1. 注:其中的字符集格式若改为“GB2312”,导出的部分数据可能为乱码: 导出之前需要关闭分 ...

  9. WPF-将DataGrid控件中的数据导出到Excel

    原文:WPF-将DataGrid控件中的数据导出到Excel 导出至Excel是非常常见,我们可以用很多类库,例如Aspose.NOPI.Interop,在这里我们使用微软自家的工具.我的WPF绑定的 ...

随机推荐

  1. luoguP3768 简单的数学题

    题目链接 luoguP3768 简单的数学题 题解 上面那个式子的最后一步,需要定理 用数学归纳法证明 \(S1=1^3=1^2\) \(S2=1^3+2^3=9=3^2=(1+2)^2\) \(S3 ...

  2. MVVM模式下关闭窗口的实现

    通过行为来实现 实现界面与逻辑的分离 窗口关闭行为:其中含有布尔型的Close属性,将相应的关闭行为绑定到该属性上,则可以实现窗口的关闭行为,从而实现VM与View的分离 public class W ...

  3. 关于输出螺旋矩阵的demo

    输出类似 1 2 3 8 9 4 7 6 5 主要难点是如何找到表示的算法 我的理解是,先生成一个n*n的矩阵,然后再往里面塞数字,而塞的方法分别有四种:由左往右,由上往下,由右往左,由下往上,没塞完 ...

  4. svn简单记录

    记录一下工作中常用到的svn命令 一.文件的提交流程 1.svn up   // 先更新本地文件 2.svn st   // svn status 查看要提交的文件 3.#svn ci -m &quo ...

  5. WAP2.0(XHTML MP)基础介绍

    (一)XHTML MP 介绍XHTML MP(eXtensible HyperText Markup Language Mobile Profile)WAP2.0与WCSS(WAP CSS /WAP ...

  6. DWZ(JUI) 教程 跨域请求 iframeNavTab

    如果想navTab访问其他的网址,可以使用 iframe  navTab 使用时也非常简单 <li><a href="http://www.baidu.com"  ...

  7. 利用 PHP 导出 Git 某个分支下,新增或修改过的文件

    使用 SVN 作为版本控制的时候,整理过一个 导出文件脚本:利用 PHP 导出 SVN 新增或修改过的文件 现在换成了 Git,整理出类似的脚本: [第一版]git.php <?php /** ...

  8. Groovy中Closure的this到底指向谁?

    Groovy in Action(中文版)第136页明确说Closure的this指向Closure自己.并且从代码注释处作者也是这样理解的: class Mother{    int field = ...

  9. leetcode第一刷_Unique Binary Search Trees

    这道题事实上跟二叉搜索树没有什么关系,给定n个节点,让你求有多少棵二叉树也是全然一样的做法.思想是什么呢,给定一个节点数x.求f(x),f(x)跟什么有关系呢,当然是跟他的左右子树都有关系.所以能够利 ...

  10. [Asp.net mvc]Html.ValidationSummary(bool)

    摘要 对ValidationSummary是HtmlHelper的扩展方法,用来返回 System.Web.Mvc.ModelStateDictionary (即ModelState)对象中的验证消息 ...