更新:
使用开源 ExcelDataReader ( https://www.nuget.org/packages/ExcelDataReader/ ) 解决了这个问题。
我正在从这样的 .xlsx 文件中读取数据
DataSet ds = new DataSet();
OleDbConnection cn = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + path + ";Extended Properties= Excel 12.0;");
cn.Open();
OleDbDataAdapter da = new OleDbDataAdapter("SELECT * FROM ["Sheet1$"]", cn);
da.Fill(ds, "Sheet1$");
cn.Close();
一切似乎都工作正常,但在两个特定行中,适配器只是切断了一个单元格的最后一行(两个受影响的行在该特定单元格中具有相同的内容)。
IE:
"1 : 0x01 : Text_Example1(sometext)
2 : 0x02 : Text_Example2(sometext)
3 : 0x04 : TexT_Example3(sometext)"
becomes
"1 : 0x01 : Text_Example1(sometext)
2 : 0x02 : Text_Example2(sometext)
3 :"
这里有什么问题,我该如何解决?对我来说,这似乎完全是随机的,因为在所有其他行中都不会出现这个问题。
编辑:我已经尝试过扩展属性 HDR = NO/YES 和 IMEX = 0/1,就像许多相关问题上所建议的那样,但这也没有奏效。