C#操作EXCEL DataTable转换的实例代码
//加载excel
public dataset loaddatafromexcel(string filepath)
{
try
{
string strconn;
//strconn = "provider=microsoft.jet.oledb.4.0;data source=" + filepath + ";extended properties='excel 8.0;hdr=false;imex=1'";
strconn = string.format("provider=microsoft.ace.oledb.12.0;data source={0};extended properties='excel 8.0;hdr=yes;imex=1;'", filepath);
oledbconnection oleconn = new oledbconnection(strconn);
oleconn.open();
string sql = "select * from [sheet1$]";//可是更改sheet名称,比如sheet2,等等
oledbdataadapter oledaexcel = new oledbdataadapter(sql, oleconn);
dataset oledsexcle = new dataset();
oledaexcel.fill(oledsexcle, "sheet1");
oleconn.close();
return oledsexcle;
}
catch (exception err)
{
return null;
}
}
/// <summary>
/// datatable直接导出excel,此方法会把datatable的数据用excel打开,再自己手动去保存到确切的位置
/// </summary>
/// <param name="dt">要导出excel的datatable</param>
/// <returns></returns>
public bool doexport(system.data.datatable dt)
{
microsoft.office.interop.excel.application app = new applicationclass();
if (app == null)
{
throw new exception("excel无法启动");
}
app.visible = true;
workbooks wbs = app.workbooks;
workbook wb = wbs.add(missing.value);
worksheet ws = (worksheet)wb.worksheets[1];
int cnt = dt.rows.count;
int columncnt = dt.columns.count;
// *****************获取数据********************
object[,] objdata = new object[cnt + 1, columncnt]; // 创建缓存数据
// 获取列标题
for (int i = 0; i < columncnt; i++)
{
objdata[0, i] = dt.columns[i].columnname;
}
// 获取具体数据
for (int i = 0; i < cnt; i++)
{
system.data.datarow dr = dt.rows[i];
for (int j = 0; j < columncnt; j++)
{
objdata[i + 1, j] = dr[j];
}
}
//********************* 写入excel******************
range r = ws.get_range(app.cells[1, 1], app.cells[cnt + 1, columncnt]);
r.numberformat = "@";
//r = r.get_resize(cnt+1, columncnt);
r.value2 = objdata;
r.entirecolumn.autofit();
app = null;
return true;
}
如对本文有疑问,
点击进行留言回复!!
相关文章:
-
C#实现猜数字游戏
本文实例为大家分享了c#实现猜数字游戏具体代码,供大家参考,具体内容如下给定一个0-100的随机数字猜其大小题目样式:电脑产生一个0到100之间的随机数字,并且...
[阅读全文]
-
-
-
C# 可空类型的具体使用
在项目中我们经常会遇到可为空类型,那么到底什么是可为空类型呢?下面我们将从4个方面为大家剖析。1、可空类型基础知识顾名思义,可空类型指的就是某个对象类型可以为空...
[阅读全文]
-
-
-
C#实现猜数字小游戏
本文实例为大家分享了c#实现猜数字小游戏的具体代码,供大家参考,具体内容如下效果如图:代码:using system;using system.collecti...
[阅读全文]
-
-
C#实现简单俄罗斯方块
最近在看《.net游戏编程入门经典 c#篇》 第一章介绍了如何制作俄罗斯方块,自己试了试按照书上的步骤,可算是完成了。于是写下这篇文章留作纪念。1.类的设计在充...
[阅读全文]
-
-
网友评论