Maison > développement back-end > C++ > Comment fusionner des cellules en double dans la première colonne d'un WinForms DataGridView ?

Comment fusionner des cellules en double dans la première colonne d'un WinForms DataGridView ?

Mary-Kate Olsen
Libérer: 2025-01-12 15:21:47
original
328 Les gens l'ont consulté

How to Merge Duplicate Cells in a WinForms DataGridView's First Column?

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 :

  1. Trouver les valeurs en double :

    • Créez une méthode nommée 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>
Copier après la connexion
  1. Dessin de cellule :

    • Remplacez le gestionnaire d'événements 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>
Copier après la connexion
  1. Formatage des cellules :

    • Remplacez le gestionnaire d'événements 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>
Copier après la connexion
  1. Autres paramètres :

    • Définissez 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>
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal