操作平台:
win7 64位
+
office2007(64)位
+
vs2010
+
sql server 2008
操作时产生错误的处理方案
操作错误一导入excel错误:外部表不是预期的格式 解决方案
解决方法:
环境:win7+iis7+Office2007
在asp.net网站中导出Excel文件后,再把文件导入到数据库中。 读取Excel文件时,打开连接出错。
错误为:外部表不是预期的格式
解决:检查了一下,导出的Excel是标准文件不是html,没错,Excel文件正常。
调试代码,创建连接对象oleDbConnection也正常,但在conn.Open()打开链接时出错。
仔细看了下链接字符串,检查出了错误,Excel版本问题,Exce连接字符串版本是office2003的 ,更改为Excel2007版本则正常导入。
总结规则如下:
using System.Data.OleDb; using System.Data; publicvoid ReadExcelFiless() { //string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + Server.MapPath("ExcelFiles/MyExcelFile.xls") + ";Extended Properties='Excel 8.0; HDR=Yes; IMEX=1'"; //此连接只能操作Excel2007之前(.xls)文件string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Server.MapPath("ExcelFiles/Mydata2007.xlsx") + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串) //备注: "HDR=yes;"是说Excel文件的第一行是列名而不是数据,"HDR=No;"正好与前面的相反。
// "IMEX=1 "如果列中的数据类型不一致,使用"IMEX=1"可必免数据类型冲突。 OleDbConnection conn = new OleDbConnection(strConn); OleDbDataAdapter adp = new OleDbDataAdapter("Select * from [Sheet1$]", conn); DataSet ds = new DataSet(); adp.Fill(ds, "Book1"); this.GridView1.DataSource = ds.Tables["Book1"].DefaultView; this.GridView1.DataBind(); }
操作错误2
:未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序解决办法
通常的解决方法 重新安装office2007
在论坛中提到过此问题 造成这种错误通常发生在sv2010 安装在office2007之后 所以 在安装完sv2010之后在重新安装office2007即可解决这种类似的问题
datagridview空间 导入与导出到excel
一下是实现读取excel的最简模式
using System.Data.OleDb;
private void button1_Click(object sender, EventArgs e)
{
try
{
string str