【发布时间】:2020-12-30 09:09:03
【问题描述】:
是否可以使用 Oledb 将数据写入普通的 excel 中?
没有表结构或任何东西,它是一个用户文档。
当我尝试时,我总是遇到 OleDbException
- “INSERT”查询回复: 操作必须使用可更新的应用程序。
- “更新”查询回复: 没有为一个或多个必需参数指定值。
我的代码:
using (OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + @"C:\Users\[...]\Classeur.xls" + ";Extended Properties=\"Excel 8.0;HDR=NO;IMEX=1;READONLY=FALSE\""))
{
connection.Open();
OleDbCommand commande = new OleDbCommand(
"INSERT INTO [Feuil1$](F1,F2,F3) VALUES ('A3','B3','C3');", connection);
commande.ExecuteNonQuery();
connection.Close();
connection.Dispose();
}
新测试(没有成功!):
using (OleDbConnection connection = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + @"C:\Users\[...]\Classeur.xls" + ";Extended Properties=\"Excel 8.0;HDR=NO;IMEX=1;READONLY=FALSE\""))
{
string column = "A";
string row = "1";
string worksheetName = "Feuil1";
string data = "TEST";
connection.Open();
string commandString = String.Format("UPDATE [{0}${1}{2}:{1}{2}] SET F1='{3}'", worksheetName, column, row, data);
OleDbCommand commande = new OleDbCommand(
commandString, connection);
connection.Close();
connection.Dispose();
}
【问题讨论】:
-
看this的文章
-
我已经下载了这个项目(具有不适合我的功能正是单元版本),并且在他的代码中他使用像我这样的更新.. 我在 FrameWork 3.5 上,也许是一个原因?
-
我认为不是固件版本的原因。提供者不同于文章中的代码到你的代码
-
他使用:“Jet OLEDB 4.0”(适用于 Excel 8)和“Ace OLEDB 12.0”(适用于 Excel 12)我尝试更改提供程序、版本、excel 文件的版本(交叉测试)和每次都是同样的错误!而且,在我的查询中,F1 是列,但我从不指定行。什么可以解释错误,但我没有看到任何指定它的示例。
-
您下载的课程也出现同样的错误?