我试图从CSV文件获取数据,通过填写()方法,我有一个例外IDK的为什么它出现时,请查看代码并建议乐观的答案。如果参数“s”没有任何空格意味着它可以正常工作。如果有空间意味着如何克服这一点,不建议临时重命名和所有。IErrorInfo.GetDescription失败,E_FAIL(0x80004005的).System.Data而数据适配器填充()
/// <summary>
/// Import Function For CSV Delimeted File
/// </summary>
/// <param name="s">File Name</param>
private DataTable Import4csv(string s)
{
string file = Path.GetFileName(s);
string dir = Path.GetDirectoryName(s);
string sConnection = "Provider=Microsoft.Jet.OLEDB.4.0;"
+ "Data Source=\"" + dir + "\\\";"
+ "Extended Properties=\"text;HDR=YES;FMT=Delimited\"";
try
{
var objConn = new OleDbConnection(sConnection);
objConn.Open();
var ds = new DataSet();
var da = new OleDbDataAdapter("SELECT * FROM " + file, sConnection);
da.Fill(ds); // getting exception on this line.
objConn.Close();
return ds.Tables[0];
}
catch (Exception ex)
{
Trace.WriteLine(ex.Message + ex.Source);
return null;
}
}
它不工作。 –
固定它,你需要之前有空格的文件名后使用'字符 – shobhonk