ExcelファイルをデータグリッドビューにインポートするWinformアプリがあります。うまく機能していますが、問題は 1 つだけです。Excel ファイルに整数の列が 2 つあります。その列のいずれかから値を変更し、整数ではない char を追加すると、データグリッドビューに値がありません。
列のタイプが元々 'Double' であるため、Excel ファイルの列のプロパティを 'Text' に変更しようとしましたが、それでもデータグリッドビューには影響しません。
また、必要なタイプ(すべて文字列として)で独自の列を作成してから、データテーブルを複製し、複製したものを datagridview に追加しようとしましたが、それでも同じ問題です。
インポートボタンをクリックしたときのコードは次のとおりです。
private void btnImport_Click(object sender, EventArgs e)
{
#region Import from the Excel
try
{
string pathConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + txtPath.Text + ";Extended Properties=\"Excel 8.0;HDR=Yes;\";";
OleDbConnection conn = new OleDbConnection(pathConn);
OleDbDataAdapter myDataAdapter = new OleDbDataAdapter("Select * from [" + sheetName + "$]", conn);
System.Data.DataTable dt = new System.Data.DataTable();
myDataAdapter.Fill(dt);
System.Data.DataTable dtCloned = dt.Clone();
foreach (DataColumn col in dtCloned.Columns)
{
col.DataType = typeof(String);
}
foreach (DataRow row in dt.Rows)
{
dtCloned.ImportRow(row);
}
ExceldataGridView.DataSource = dtCloned;
dt.Dispose();
myDataAdapter.Dispose();
conn.Close();
}
catch
{
MessageBox.Show("Error");
return;
}
#endregion
}