我在C#中创建了一个Windows应用程序,我使用excel作为临时数据库。我能够读取excel数据,但我不知道如何使用C#更新该文件中的单元格值。
结构如下:
我希望在完成执行后将完成字段更新为yes
。
答案 0 :(得分:1)
如果您使用excel作为OLEDB数据源,那么您将使用SQL,就像它是一个数据库一样。 查询看起来有点像:
SELECT [Column Name One], [Column Name Two] FROM [Sheet One$]
在你的情况下
UPDATE [Sheet One$]
SET [column1]=value, [done]='yes'
WHERE [some_column]=some_value
如果您需要更多帮助,请查看大量有关此信息的信息。 也许http://www.codeproject.com/Articles/8500/Reading-and-Writing-Excel-using-OLEDB会帮助你开始。
答案 1 :(得分:1)
我必须更新
Extended Properties=HDR=NO; IMEX=1
与
Extended Properties=HDR=YES;
所以它将是:
connString = "Provider=Microsoft.Jet.OLEDB.4.0;Excel 8.0; Extended Properties=HDR=YES;Data Source=" + Directory.GetCurrentDirectory() + "/swtlist.xls";
OleDbConnection oledbConn = new OleDbConnection(connString);
oledbConn.Open();
DataTable dt = oledbConn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
OleDbCommand cmd = new OleDbCommand("UPDATE [Sheet1$] SET done='yes' where id=1", oledbConn);
cmd.ExecuteNonQuery();