c#做公司的应用级开发时,导出数据这个是经常要做的,公司使用的是一个叫NPOI的组件。具体是什么我就不很清楚,反正这样用就是了。
具体的dll是一个叫:NPOI.HSSF.dll,引入这个dll,这个dll提供HSSFWorkbook类 HSSFSheet类HSSFRow类;
具体实现方式直接看代码吧:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
public static Stream DataSetToExcel(DataSet _SourceDt, string _sheetName) { HSSFWorkbook workbook = new HSSFWorkbook(); MemoryStream MS = new MemoryStream(); string [] sheetNames= _sheetName.Split( ',' ); for ( int i = 0; i <sheetNames.Length;i++) { HSSFSheet sheet = workbook.Cretesheet(sheetNames[i]); HSSFRow headRow = sheet.CreateRow(0); foreach (DataColumn column in _SourceDt.Table[i].cloumns) headRow.createCell(column.Ordinal).SetCellValue(column.Column.Name); int rowIndex =1; foreach (DataRow row in _SourceDt.Tables[i].Rows) { HSSFRow dataRow = sheet.CreateRow(rowIndex); foreach (DataColumn column in _SourceDt.Tables[i].Columns) { dataRow.CreateCell(column.Ordinal).SetCellValue(row[column].ToString()); } rowIndex++; } } workbook.write(MS); MS.Flush(); MS.Position = 0; workbook = null ; return MS; } |
主要是要构建一个数据来源的DataSet ;还是直接上代码吧:
1
2
3
4
5
6
7
8
9
10
11
12
|
DataTable dt = new DataTable(); DataSet DataTemp = new DataSet(); dt.Columns.Add( "列名1" , string ); dt.Columns.Add( "列名2" , string ); for ( int i = 0;i<3;i++) { DataRow DR = dt.NewRow(); DR[ "列名1" ] = "DATA1" ; DR[ "列名2" ] = "DATA1" ; dt.Rows.Add(DR); } DataTemp.Tables.Add(dt); |
DATA1和DATA2就是你要导出的数据了。
以上不是开发的源代码,只是方法。仅供参考;
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/chenqiangdage/article/details/19576391