博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# DataSet数据导入Excel 修正版- .net FrameWork 4.0以上
阅读量:6564 次
发布时间:2019-06-24

本文共 3794 字,大约阅读时间需要 12 分钟。

引入  Microsoft.Office.Interop.Excel.dll  格式:标题加了下划线,单元格内容居中  1 using System; 2 using System.Data; 3 using System.Data.SqlClient; 4 using System.Web.UI;     5  6      public static void DataSetToExcel(DataTable dataTable, string SaveFile)   7             {   8                 Microsoft.Office.Interop.Excel.Application excel;   9 10                 Microsoft.Office.Interop.Excel._Workbook workBook;  11 12                 Microsoft.Office.Interop.Excel._Worksheet workSheet;  13 14                 object misValue = System.Reflection.Missing.Value;  15 16                 excel = new Microsoft.Office.Interop.Excel.Application();17 18                 workBook = excel.Workbooks.Add(misValue);  19 20                 workSheet = (Microsoft.Office.Interop.Excel._Worksheet)workBook.ActiveSheet;  21 22                 int rowIndex = 1;  23 24                 int colIndex = 0;25                26                 //取得标题  27                 foreach (DataColumn col in dataTable.Columns)  28                 {  29                     colIndex++;  30 31                     excel.Cells[1, colIndex] = col.ColumnName;32                     Microsoft.Office.Interop.Excel.Range range = workSheet.Range[workSheet.Cells[1, colIndex],workSheet.Cells[1,colIndex]];33                     range.Font.Underline = true;34                 }35 36                 //取得表格中的数据  37                 foreach (DataRow row in dataTable.Rows)  38                 {  39                     rowIndex++;  40 41                     colIndex = 0;  42 43                     foreach (DataColumn col in dataTable.Columns)  44                     {  45                        colIndex++;  46 47                        excel.Cells[rowIndex, colIndex] =   48 49                             row[col.ColumnName].ToString().Trim();50 51                        Microsoft.Office.Interop.Excel.Range range = workSheet.Range[excel.Cells[rowIndex, colIndex], excel.Cells[rowIndex, colIndex]];52                        range.HorizontalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignCenter;53                     }  54                 }  55 56                 excel.Visible = false;57                 excel.DisplayAlerts = false;58 59                 if (workSheet != null)60                 {61                     workBook.SaveAs(SaveFile, Microsoft.Office.Interop.Excel.XlFileFormat.xlWorkbookNormal, misValue,62 63                         misValue, misValue, misValue, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlExclusive,64 65                         misValue, misValue, misValue, misValue, misValue);66                 }67  68 69                 dataTable = null;  70 71                 workBook.Close(true, misValue, misValue);  72 73                 excel.Quit();  74 75 76                 releaseObject(workSheet);  77 78                 releaseObject(workBook);  79 80                 releaseObject(excel);  81 82             }  83 84             private static void releaseObject(object obj)  85             {  86                 try  87                 {  88                     System.Runtime.InteropServices.Marshal.ReleaseComObject(obj);  89                     obj = null;  90                 }  91                 catch  92                 {  93                     obj = null;  94                 }  95                 finally  96                 {  97                     GC.Collect();  98                 }  99             }

Call funxction example:

DataSetToExcel(ds.Tables[0], @"D:\ZhaoNick\Desktop\test.xls");

这次需要做一个windowServices,主要的功能就是从local db提取数据存入ftp excel file中,在提取数据成功后存入dataset中,在导入到excel时要给标题加下划线和内容设置居中时,发现报了“Microsoft.CSharp.RuntimeBinder.RuntimeBinderException: “object”未包含“get_Range”的定义”这么一段错误,后来才发现是.net版本问题或者说是写法有问题。。不过最后还是解决了这个坑。

转载于:https://www.cnblogs.com/kejie/p/7230222.html

你可能感兴趣的文章
2019 -2-15 复习
查看>>
vim锁定屏幕
查看>>
实用的 JavaScript 调试小技巧
查看>>
027移除元素
查看>>
Linux下清理内存和Cache方法
查看>>
CodeVS 1018 单词接龙(DFS)
查看>>
我的博客园的CSS和html设置
查看>>
android launchmode(四种启动模式)应用场景及实例
查看>>
工作中简单的kettle使用
查看>>
spark shuffle:分区原理及相关的疑问
查看>>
C#匿名委托
查看>>
Laravel5.5 使用第三方Vendor添加注册验证码
查看>>
06- Linux下sublime下载与使用
查看>>
前端文摘:Web 开发模式演变历史和趋势
查看>>
将图片序列转化为视频文件
查看>>
jQuery的文档操作***
查看>>
CODING Pages 服务全面升级,更快更稳更可靠!
查看>>
js 小数取整,js 小数向上取整,js小数向下取整
查看>>
从头到尾彻底理解KMP
查看>>
mysql 自定义函数与自定义存储过程的调用方法
查看>>