Maison >développement back-end >C++ >Comment fusionner des cellules en double dans la première colonne d'un WinForms DataGridView ?
Fusion de cellules WinForms DataGridView
Question :
Dans DataGridView, les données sont organisées sous forme de grille, contenant des lignes et des colonnes. Chaque intersection de ligne et de colonne est représentée par une cellule. Dans cet exemple, les données sont affichées dans un format tel que les valeurs en double dans la première colonne (Hd1) ne sont pas fusionnées, ce qui entraîne plusieurs lignes pour la même valeur.
Exigences :
L'objectif est de fusionner les cellules avec des valeurs en double dans la première colonne (Hd1) pour améliorer les visuels et consolider efficacement les données.
Solution :
Pour fusionner des cellules dans DataGridView, vous pouvez suivre ces étapes :
Trouver les valeurs en double :
IsTheSameCellValue
qui compare les valeurs de deux cellules adjacentes dans la première colonne. Si les valeurs sont les mêmes, true
est renvoyé, sinon false
est renvoyé. <code class="language-csharp">bool IsTheSameCellValue(int column, int row) { DataGridViewCell cell1 = dataGridView1[column, row]; DataGridViewCell cell2 = dataGridView1[column, row - 1]; if (cell1.Value == null || cell2.Value == null) { return false; } return cell1.Value.ToString() == cell2.Value.ToString(); }</code>
Dessin de cellule :
CellPainting
et modifiez la propriété AdvancedBorderStyle
de la cellule : <code class="language-csharp">private void dataGridView1_CellPainting(object sender, DataGridViewCellPaintingEventArgs e) { e.AdvancedBorderStyle.Bottom = DataGridViewAdvancedCellBorderStyle.None; if (e.RowIndex < 1 || e.ColumnIndex < 0) return; if (IsTheSameCellValue(e.ColumnIndex, e.RowIndex)) { e.AdvancedBorderStyle.Top = DataGridViewAdvancedCellBorderStyle.None; } else { e.AdvancedBorderStyle.Top = dataGridView1.AdvancedCellBorderStyle.Top; } }</code>
Formatage des cellules :
CellFormatting
pour définir la valeur sur une chaîne vide si la cellule est un doublon : <code class="language-csharp">if (e.RowIndex == 0) return; if (IsTheSameCellValue(e.ColumnIndex, e.RowIndex)) { e.Value = ""; e.FormattingApplied = true; }</code>
Autres paramètres :
dataGridView1.AutoGenerateColumns
sur false
dans l'événement de chargement du formulaire pour empêcher la génération automatique des colonnes. <code class="language-csharp">dataGridView1.AutoGenerateColumns = false;</code>
Résultat :
L'exécution de ces étapes fusionnera les cellules avec des valeurs en double dans la première colonne du DataGridView, rendant l'affichage des données plus compact et organisé.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!