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. python tcp 实时抓包

    问题:之前我们系统上线后,因为是旧的系统,没有加统计的功能,比如用户喜欢那个页面,是哪些用户再访问,接口的负载能力等等. 解决办法:1,现有代码更改,添加功能.现有代码侵入太多,工作量比较大 2,想到 ...

  2. 一个页面从输入 URL 到页面加载显示完成,这个过程中都发生了什么?

    分为4个步骤: 1)  当发送一个 URL 请求时,不管这个 URL 是 Web 页面的 URL 还是 Web 页面上每个资源的 URL,浏览器都会开启一个线程来处理这个请求,同时在远程 DNS 服务 ...

  3. CentOS 7 上安装vim 解決 centos -bash: vim: command not found

    用CentOS上使用vim竟然用不了,报错没有该命令 centos -bash: vim: command not found 那么如何安裝 vim 呢? ---------------------- ...

  4. jersey练习

    package com.tz.router; import java.util.ArrayList; import java.util.Date; import java.util.List; imp ...

  5. no acceptable C compiler found in $PATH

    安装gcc编译器 yum install -y gcc 参考: http://blog.51cto.com/raulkang/573151

  6. 用docker搭建ss访问火星

    最近弄了个vultr的VPS,便想用它搭个梯子访问火星.由于vultr是支持docker的,便找了个ss的docker镜像: https://hub.docker.com/r/mritd/shadow ...

  7. 关于ConcurrentDictionary的线程安全

    ConcurrentDictionary是.net BCL的一个线程安全的字典类,由于其方法的线程安全性,使用时无需手动加锁,被广泛应用于多线程编程中.然而,有的时候他们并不是如我们预期的那样工作. ...

  8. android开发之GestureDetector手势识别(调节音量、亮度、快进和后退)

    写UI布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:andro ...

  9. 交叉编译Python-3.6.0到aarch64/aarch32 —— 支持sqlite3

    参考 https://datko.net/2013/05/10/cross-compiling-python-3-3-1-for-beaglebone-arm-angstrom/ 平台 主机: ubu ...

  10. 在ASP.NET MVC实现购物车,尝试一种不同于平常的购物车显示方式

    通常,我们看到的购物车是这样的: 虽然这种购物车显示方式被广泛运用,但我个人觉得不够直观.如果换成这样呢? 本篇的源码放在了:https://github.com/darrenji/ShoppingC ...