Précédent   Forum du club des développeurs et IT Pro > Dotnet > Général Dotnet > Développement Office System
Développement Office System Forum d'entraide pour toute question concernant le développement DotNet autour d'Office et Sharepoint
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse
 
Outils de la discussion
Publicité
'
Vieux 14/11/2012, 15h21   #1
Themacleod1980
Membre éclairé
 
Homme Décapiteur de bug
Développeur informatique
Inscription : décembre 2005
Messages : 286
Détails du profil
Informations personnelles :
Nom : Homme Décapiteur de bug
Âge : 32

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

Informations forums :
Inscription : décembre 2005
Messages : 286
Points : 330
Points : 330
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 :
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)
Themacleod1980 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/11/2012, 17h20   #2
Themacleod1980
Membre éclairé
 
Homme Décapiteur de bug
Développeur informatique
Inscription : décembre 2005
Messages : 286
Détails du profil
Informations personnelles :
Nom : Homme Décapiteur de bug
Âge : 32

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

Informations forums :
Inscription : décembre 2005
Messages : 286
Points : 330
Points : 330
Réponse à moi même :

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

Code :
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 :
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)
Themacleod1980 est déconnecté   Envoyer un message privé Réponse avec citation 10
Réponse Cette discussion est résolue.
Outils de la discussion

Navigation rapide


Fuseau horaire GMT +2. Il est actuellement 17h37.


 
 
 
 
Partenaires

Hébergement Web