c#做公司的应用级开发时,导出数据这个是经常要做的,公司使用的是一个叫NPOI的组件。具体是什么我就不很清楚,反正这样用就是了。
具体的dll是一个叫:NPOI.HSSF.dll,引入这个dll,这个dll提供HSSFWorkbook类 HSSFSheet类HSSFRow类;
具体实现方式直接看代码吧:
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 ;还是直接上代码吧:
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就是你要导出的数据了。
以上不是开发的源代码,只是方法。仅供参考;
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对亿速云的支持。如果你想了解更多相关内容请查看下面相关链接
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。