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. NOIP练习赛题目6

    长途旅行 难度级别:A: 运行时间限制:3000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 JY 是一个爱旅游的探险家,也是一名强迫症患者.现在JY 想要在C ...

  2. 【原】Spring整合Redis(第三篇)—盘点SDR搭建中易出现的错误

    易错点01:Spring版本过低导致的错误[环境参数]Redis版本:redis-2.4.5-win32-win64Spring原来的版本:4.1.7.RELEASESpring修改后的版本:4.2. ...

  3. spring cloud 学习(4) - hystrix 服务熔断处理

    hystrix 是一个专用于服务熔断处理的开源项目,当依赖的服务方出现故障不可用时,hystrix有一个所谓的断路器,一但打开,就会直接拦截掉对故障服务的调用,从而防止故障进一步扩大(类似中电路中的跳 ...

  4. [原创]App性能测试指标篇

    [原创]App性能测试指标篇 目前由于苹果,三星等大厂对智能手机的研发及投入,使的智能手机发展非常迅速,每个人手中都有一些离不开生活的App,如:微信,微博,百度或是各游戏App等,但是到底App性能 ...

  5. 使用ptrace向已运行进程中注入.so并执行相关函数(转)

    1. 简介 使用ptrace向已运行进程中注入.so并执行相关函数,其中的“注入”二字的真正含义为:此.so被link到已运行进程(以下简称为:目标进程)空间中,从而.so中的函数在目标进程空间中有对 ...

  6. systemtap跟踪C

    1.[root@localhost ~]# rpm -qi  glibcName        : glibc                        Relocations: (not rel ...

  7. [Winform]setupfactory打包时添加开机自启动的脚本

    摘要 如果有这样的需求,需要软件开机自启动,该如何做呢?开机自启动的做法,就是修改注册表,将你的exe注册到注册表Run节点下. setupfactory 在安装的时候需要以管理员身份运行,这样可以保 ...

  8. 大数据以及Hadoop相关概念介绍

    一.大数据的基本概念 1.1.什么是大数据 大数据指的就是要处理的数据是TB级别以上的数据.大数据是以TB级别起步的.在计算机当中,存放到硬盘上面的文件都会占用一定的存储空间,例如: 文件占用的存储空 ...

  9. spring Quartz基于配置文件和注解的实现

    这里仅仅是做简单的记录怎样实现. 一.基于配置文件的实现 ①编写须要调度的类 package com.study; import org.springframework.scheduling.anno ...

  10. C#中一种替换switch语句更优雅的写法

    今天在项目中遇到了使用switch语句判断条件,但问题是条件比较多,大概有几十个条件,满屏幕的case判断,是否有更优雅的写法替代switch语句呢? 假设有这样的一个场景:商场经常会根据情况采取不同 ...