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

Développement Office System .NET Discussion :

Font Excel Débile ?


Sujet :

Développement Office System .NET

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

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

    Informations forums :
    Inscription : Décembre 2005
    Messages : 482
    Points : 625
    Points
    625
    Par défaut Font Excel Débile ?
    Salut,

    Je me suis fait une appli qui crée un document Excel.

    Dans ce document, je voudrais :
    1- créer un titre sur plusieurs cellules fusionnées
    2- centrer ce titre
    3- le mettre en gras, taille 14

    Voici mon bout de code :
    (pour info, le MSExcel est un Alias : using MSExcel = Microsoft.Office.Interop.Excel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
    //Hop, je défini mon onglet
    MSExcel.Worksheet workSheet_PDC = (MSExcel.Worksheet)objExcel.ActiveWorkbook.Worksheets.Add(Type.Missing, Type.Missing, Type.Missing, Type.Missing);
    //paf, je nomme mon onglet
    workSheet_PDC.Name = "TrucBiduleChoseMachin";
    //gniak, je défini ma portée
    MSExcel.Range rangeTitre = workSheet_PDC.get_Range("A1", "X1");
    //zip, je la fusionne
    rangeTitre.Merge(false);
    //plouf, je lui met mon texte
    rangeTitre.Value2 = "Blablabla et tout le reste...";
    //et BAM je formatte le tout :)
    ((MSExcel.Style)rangeTitre.Style).Font.Bold = true;
    ((MSExcel.Style)rangeTitre.Style).Font.Size = 14;
    ((MSExcel.Style)rangeTitre.Style).HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
    Alors là ma ligne va très bien, elle est centrée, en gras et en taille 14, le tout sur ma plage fusionnée
    mais, Mais, MAIS !: le style de mon texte à changé partout !!!! sur tous les onglets, toutes les lignes, colonnes etc... même les titres de colonne ('A','B','C',etc...) et de lignes ('1','2','3',etc...) sont dans cette police ¿?

    Me suis dit que ça modifiait pit-être une instance de Font commune à tout le document (d'où le fait que c'est répliqué partout) et ai voulu me créer une nouvelle instance à appliquer uniquement sur mon chTitre : bah non, il veut pÔ parce que :
    1- MSExcel.Font est une interface (et donc n'a pas de constructeur)
    2- Style.Font est en lecture seule (ouai super !)

    Quelqu'un connait-il ce problème ?
    Les exemples que je vois sur le net semblent identiques à ce que j'ai fait au niveau des fonts mais tout le monde semble considérer que c'est ok alors ma version est boguée ?¿

    infos supplémentaires :
    La DLL Excel référencée : Microsoft.Office.Interop.Excel Version V11.0.0.0 Version du runtime V1.1.4322

    (d'ailleurs, maintenant que j'écris ces lignes, je me rend compte que je n'ai pas tenté d'instancier directement le Style (qui contient la Font), donc j'vais tester ça...)

    Merci pour l'attention portée à mon immense désarroi.
    "Essayer est le premier pas vers l'Echec !" (Homer Simpson)

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

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

    Informations forums :
    Inscription : Décembre 2005
    Messages : 482
    Points : 625
    Points
    625
    Par défaut
    Réponse à moi même :

    Ouaip, il faut avant tout créer les styles :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    MSExcel.Style styleTitre = objExcel.ActiveWorkbook.Styles.Add("Titre", Type.Missing); 
    styleTitre.Font.Bold = true;
    styleTitre.Font.Size = 14;
    styleTitre.HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignLeft;
    puis l'assigner :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    rangeTitre.Style = styleTitre;
    Heureux d'avoir pu te m'aider
    Hop résolu
    "Essayer est le premier pas vers l'Echec !" (Homer Simpson)

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

Discussions similaires

  1. [XL-2003] Macro Excel - Problème avec ActiveCell.Font.ColorIndex
    Par lezert dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 11/03/2011, 16h23
  2. Problème de font dans un fichier excel généré en java
    Par jmmaugis dans le forum Documents
    Réponses: 0
    Dernier message: 09/09/2008, 10h26
  3. [VBA-Excel]Changer font dans une textbox
    Par Mugette dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 20/10/2006, 15h48
  4. [VB.NET] font.colorindex pour excel avec .NET
    Par beegees dans le forum Windows Forms
    Réponses: 2
    Dernier message: 23/07/2006, 17h17
  5. Modifier Font d'une cellule dans Excel
    Par nmathon dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 27/05/2005, 15h42

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