我无法更改DataGridView cells
. 我生成了多个运行时DataGridView
,我正在使用以下代码:
For Each tbp As TabPage In frmTimingP2P.tabctrlTimingTable.TabPages
For Each ctrl As Control In tbp.Controls
Dim dgv As DataGridView = TryCast(ctrl, DataGridView)
If Not dgv Is Nothing Then
For Each dc As DataGridViewColumn In dgv.Columns
If dc.Name.EndsWith("Gain/Loss") Then
For Each dr As DataGridViewRow In dgv.Rows
If Not dr.Cells(dc.Index).Value Is DBNull.Value Then
If dr.Cells(dc.Index).Value = 0 Then
dr.Cells(dc.Index).Style.ForeColor = Color.Blue
ElseIf dr.Cells(dc.Index).Value < 0 Then
dr.Cells(dc.Index).Style.ForeColor = Color.Red
ElseIf dr.Cells(dc.Index).Value > 0 Then
dr.Cells(dc.Index).Style.ForeColor = Color.Green
End If
End If
Next
End If
Next
dgv.Refresh()
End If
Next
Next
此代码仅适用于当前关注的 DataGridView,但不适用于其他DataGridview
。
我已经修改了我的代码,现在提出了以下内容:
Private Sub dgvOverview_CellFormatting(sender As Object, e As System.Windows.Forms.DataGridViewCellFormattingEventArgs) Handles dgvOverview.CellFormatting
Dim dgv As New DataGridView
dgv = sender
If dgv.Columns(e.ColumnIndex).Name.EndsWith("Gain/Loss") Then
If e.Value IsNot DBNull.Value Then
Dim intCellValue As Integer = CType(e.Value, Integer)
If intCellValue = 0 Then
e.CellStyle.ForeColor = Color.Blue
ElseIf intCellValue > 0 Then
e.CellStyle.ForeColor = Color.Green
ElseIf intCellValue < 0 Then
e.CellStyle.ForeColor = Color.Red
End If
End If
End If
End Sub
这一切都很好。谢谢您的帮助!