用OLEDB的方法向EXCEL中写字符串出错(写入数字没问题). 提示Data type mismatch in criteria expression. 可是我的cell format已经是 general. 数据类型是兼容的啊!不知道是什么原因.还请高人解答

解决方案 »

  1.   

    /// 
    /// 写入Excel文档
    /// 
    /// 文件名称
    public bool SaveFP2toExcel(string Path)
    {
    try
    {
    string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" +"Data Source="+ Path +";"+"Extended Properties=Excel 8.0;";
    OleDbConnection conn = new OleDbConnection(strConn);
    conn.Open(); 
    System.Data.OleDb.OleDbCommand cmd=new OleDbCommand ();
    cmd.Connection =conn;
    //cmd.CommandText ="UPDATE [sheet1$] SET 姓名='2005-01-01' WHERE 工号='日期'";
    //cmd.ExecuteNonQuery ();
    for(int i=0;i {
    if(fp2.Sheets [0].Cells[i,0].Text!="")
    {
    cmd.CommandText ="INSERT INTO [sheet1$] (工号,姓名,部门,职务,日期,时间) VALUES('"+fp2.Sheets [0].Cells[i,0].Text+ "','"+
    fp2.Sheets [0].Cells[i,1].Text+"','"+fp2.Sheets [0].Cells[i,2].Text+"','"+fp2.Sheets [0].Cells[i,3].Text+
    "','"+fp2.Sheets [0].Cells[i,4].Text+"','"+fp2.Sheets [0].Cells[i,5].Text+"')";
    cmd.ExecuteNonQuery ();
    }
    }
    conn.Close ();
    return true;
    }
    catch(System.Data.OleDb.OleDbException ex)
    {
    System.Diagnostics.Debug.WriteLine ("写入Excel发生错误:"+ex.Message );
    }
    return false;
    }