我有一个OLDB连接将csv文件读入数据集。现在在CSV中我有一列像3,00或15,00(这是欧元的金额),但是当我调用OdbcDataAdapter的.Fill方法时,它将值更改为DateTime。这是我的代码用于读取CSV并将其转换为一个数据集:OLDB读取CSV文件,但它会更改值
DataSet ds = new DataSet();
try
{
// Creates and opens an ODBC connection
string strConnString = "Driver={Microsoft Text Driver (*.txt; *.csv)};Dbq=" + filePath.Trim() + ";Extensions=asc,csv,tab,txt;Persist Security Info=False";
string sql_select;
OdbcConnection conn;
conn = new OdbcConnection(strConnString.Trim());
conn.Open();
//Creates the select command text
sql_select = "select * from [" + this.fileName.Trim() + "]";
//Creates the data adapter
OdbcDataAdapter obj_oledb_da = new OdbcDataAdapter(sql_select, conn);
//Fills dataset with the records from CSV file
obj_oledb_da.Fill(ds, "csv");
//closes the connection
conn.Close();
}
catch (Exception e) //Error
{
MessageBox.Show(e.Message, "Error - LoadCSV", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
return ds;
的CSV的记录是这样的:
2005 2 20 7024 0 0 2900 14 19 0,00 3,00 3,00 0,00 0,00 0,00 15,80 18,80 0,00 0,00 90014 99999998 99999998 0 0 23/02/2005 0 stt 7024 15,80 0,00 N 60376940043 fis
从数据集接收到的记录是这样的:
2005 2 20 7024 0 0 2900 14 19 30-12-1899 0:00:00 30-12-1899 15:26:00 30-12-1899 15:26:00 30-12-1899 0:00:00 30-12-1899 0:00:00 30-12-1899 0:00:00 80,33 95,59 30-12-1899 0:00:00 30-12-1899 0:00:00 92705 99999998 99999998 0 0 23-2-2005 0:00:00 0 stt 7024 80,33 30-12-1899 0:00:00 N fis
我在这里错过了什么?因为DataSet的记录应该与CSV记录完全相同。我需要将CSV转换为DataSet,因为我不想将所有单独的行添加到数据库中,所以我一次将数据集插入到数据库中(这是导入模块)
谁能帮助我?
在此先感谢!
我错过了什么 - 你的文件逗号分隔或制表符分隔吗?它是逗号分隔文件,逗号作为小数点吗?这可能会导致一些问题。你能在文件中发布该行的确切格式吗? – Brett 2011-01-27 20:48:09
也许你需要代码中的逗号替换为`.`,现在它被解释为时间。这是我的愚见。 – 2011-01-27 20:48:47