IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C# Discussion :

Format colonne dans un datagridview


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 5
    Par défaut Format colonne dans un datagridview
    Bonjour,

    J'ai un datagridview alimenté à partir d'un fichier Excel. Ce datagridview comporte deux colonnes : la première est un code sur 9 chiffres et la seconde contient le libellé correspondant.

    Mon problème est qu'à l'exécution de mon programme, les valeurs de code commençant par un zéro ne s'affichent pas. Pour info, le code est déclaré au format texte.

    Auriez-vous une solution pour moi ?

  2. #2
    Membre chevronné
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2009
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Février 2009
    Messages : 317
    Par défaut
    Le ValueType de ta colonne affichant tes codes ne serait pas d'un type Int par hasard ? Si c'est le cas, essaye ce qui suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Mycolumn.ValueType = typeof(string);
    Attention, si tes données sont bindées avec une DataTable, tu dois modifier le type dans la DataTable

  3. #3
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 5
    Par défaut Données présentes dans un dataset
    Mes données sont dans un dataset.

    Voici mon code actuel :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    string strConn = @"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\...\lib_code.xls;Extended Properties= ""Excel 8.0;HDR=YES;""";
    OleDbConnection connexion = new OleDbConnection(strConn);
    OleDbDataAdapter da = new OleDbDataAdapter();
    connexion.Open();
    OleDbCommand objCmd = new OleDbCommand("SELECT * FROM [lib$]", connexion);
    da.SelectCommand = objCmd;
    DataSet ds = new DataSet();
    da.Fill(ds);
    connexion.Close();
     
    dataGridView1.DataSource = ds.Tables[0].DefaultView;
    Comment puis-je modifier le type de ma colonne dans ce cas ?
    J'ai essayé d'intégrer quelque chose comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     DataColumn dc = new DataColumn("Code", typeof(string));
    mais je ne vois pas comment remplacer ma colonne d'origine par celle-la.

    Merci d'avance.

  4. #4
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2005
    Messages
    482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2005
    Messages : 482
    Par défaut
    Salut,
    le problème vient sans doute du fait que la table lib$ contient le champ "code" de type Entier.

    si tu modifie le type dans le DataSet, tu ne pourras plus mettre la table d'origine à jour (si c'est ce que tu veux) car le type ne correspondra plus.

    ton idée d'ajouter une colonne de type string est bonne, mais ne servira que pour l'affichage de la donnée, il te faudra masquer la colonne 'code' d'origine et abonner un événement pour qu'à chaque ligne ajoutée tu puisses ajouter la donnée dans le tableau.

    ce que je te propose (si tu ne dois pas mettre à jour les données dans la table !!) c'est de changer ta requête en
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT CAST(Code AS VARCHAR) AS MonCode, MonAutreChamp1, MonAutreChamp2, etc... FROM [lib$]"
    ainsi ton tableau obtiendra directement une colonne de type string (varchar en SQL).
    pour les zéro à gauche j'ai un truc tout con (si quelqu'un a mieux je suis preneur :p) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT RIGHT('00000' + CAST(Code AS VARCHAR), 5) AS MonCode FROM lib$
    ça colle 5 zéros à gauche et lit les 5 caractères de droite ce qui permet d'avoir toujours une chaine de 5 chars.

  5. #5
    Nouveau membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 5
    Par défaut J'ai trouvé la solution.
    Lors de ma connexion au fichier Excel, il manquait la propriété IMEX=1.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     string strConn = @"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=C:\...\lib_code.xls;Extended Properties= ""Excel 8.0;HDR=YES;IMEX=1""";
    Le code est maintenant détecté même s'il commence par un zéro.
    En tout cas, merci de votre aide.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 6
    Dernier message: 17/06/2008, 11h28
  2. Réponses: 5
    Dernier message: 28/05/2008, 10h45
  3. Creation manuelle de colonne dans un datagridview
    Par redpopo dans le forum Windows Forms
    Réponses: 3
    Dernier message: 27/05/2008, 15h10
  4. [C#][VS 2005]Supprimer la première colonne dans un DatagridView
    Par cmoiscrat dans le forum Windows Forms
    Réponses: 2
    Dernier message: 29/06/2006, 15h20
  5. format colonnes dans un (sous-)formulaire
    Par patbeautifulday1 dans le forum IHM
    Réponses: 4
    Dernier message: 14/02/2006, 18h00

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo