DataGridView上で日付をyyMMdd形式で入力させるセルがあるのですが、そこの入力チェックがうまく動作しません。
まずは、コードからお願いします。
private void dataGridView1_CellValidating(object sender, DataGridViewCellValidatingEventArgs e) { //入力されたセルの列番号を取得 int colIndex = dataGridView1.CurrentCell.ColumnIndex; //日付入力の列であれば判定処理に入る if (colIndex == 3 || colIndex == 4) { //入力されたセルの値を取得 string cellValue = dataGridView1[colIndex, dataGridView1.CurrentCell.RowIndex].Value.ToString(); if (cellValue != "") { //値が6桁の数値であるか判定 if (System.Text.RegularExpressions.Regex.IsMatch(cellValue, @"\d\d\d\d\d\d")) { //日付として正しい値か判定 const string FORMAT = "yyMMdd"; DateTime result; if (!DateTime.TryParseExact(cellValue, FORMAT, null, System.Globalization.DateTimeStyles.AllowLeadingWhite | System.Globalization.DateTimeStyles.AllowTrailingWhite, out result)) { MessageBox.Show("正しい日付を入力してください。"); dataGridView1[colIndex, dataGridView1.CurrentCell.RowIndex].Value = ""; } } else { MessageBox.Show("yymmdd形式で入力してください。"); dataGridView1[colIndex, dataGridView1.CurrentCell.RowIndex].Value = ""; } } } }
コードの流れとしては
・入力したセルが日付を入力する列であれば、セルの値を取得する。
・フォーム終了時に入力チェックが作動しないように、値がブランクの場合は入力チェックを行わない。
・値が6桁の数字、かつyyMMdd形式か判定する。
という流れです。
問題点は、それぞれ1回目の入力では判定されず、それぞれ2回目以降の入力から判定されます。
デバッグしてわかったことは、セルの値を取得する際に、最初の時はブランクで取れてきています。
そこで質問なのですが、最初の入力から判定させるにはどうすればいいでしょうか?
コードはシングルクウォートでなくバッククウォートで括ってください。
'''(x) -> ```(o)
回答1件
あなたの回答
tips
プレビュー