fqzzNevergiveup 2017-08-03 00:21 采纳率: 0%
浏览 1107
已结题

C#读取电脑中的Excel文件,为什么有几行少读了字符串??急!!!!!!!!!!!!!!

我用C#中的OleDbConnection读取电脑中的Excel文件时,主要代码如下:

string fileType = System.IO.Path.GetExtension(filePath);

if (string.IsNullOrEmpty(fileType))

{

return;

}

string strCon = string.Format("Provider=Microsoft.ACE.OLEDB.{0}.0;" + "Extended Properties=\"Excel {1}.0;HDR={2};IMEX=1;\";" + "data source={3};", (fileType == ".xls" ? 4 : 12), (fileType == ".xls" ? 8 : 12), "NO", filePath);

OleDbConnection conn = new OleDbConnection(strCon);

conn.Open();

DataTable dtSheetName = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "Table" });

string strExcel = "select * from [" + dtSheetName.Rows[0]["TABLE_NAME"].ToString() + "$" + "]";

OleDbDataAdapter myCommand = new OleDbDataAdapter(strExcel, strCon);

DataTable dtExcel = new DataTable();

myCommand.Fill(dtExcel);

conn.Close();

结果是,能读取到Excel文件,但是返回的DataTable里,有几行少字符串, 比如说,Excel中第5行是: 【400.测量装置的误差是( )误差。A. 附加 B. 基本 C. 方法 D. 人员** 标准答案:B**】,但返回的DataTable里相对应的第5行是: 【400.测量装置的误差是( )误差。A. 附加 B. 基本 C. 方法 D. 人员** 标准答**】,注意结尾加粗处,返回的DataTable少了【**案:B**】几个字,
请问各位大神, 这是为什么?? 急!!!!!!!!!!!!

  • 写回答

3条回答 默认 最新

  • cloudyzhao 2017-08-03 00:36
    关注
    评论

报告相同问题?

悬赏问题

  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记