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

ASP.NET Discussion :

Changer le format d'une cellule excel


Sujet :

ASP.NET

  1. #1
    Débutant   Avatar de SonnyFab
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    498
    Détails du profil
    Informations personnelles :
    Âge : 34

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2010
    Messages : 498
    Points : 213
    Points
    213
    Par défaut Changer le format d'une cellule excel
    Bonjour,
    voila j'exporte mon repeater dans un fichier excel, mais il s'avère que mon repeater est composé d'un champ contenant des numéros commençant par 0.
    Ainsi dans le fichier excel tous les 0 sont homis. Le problème aparemment vient du format des cellules et j'arrête pas de fouiller sur le net comment changé ce format en texte depuis mon code ci-dessus.
    Si quelqu'un connait un lien ou un code qui pourrait m'aider je le supplie de m'aider.

    Merci d'avance.

  2. #2
    Expert éminent sénior

    Avatar de Philippe Vialatte
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2004
    Messages
    3 029
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juillet 2004
    Messages : 3 029
    Points : 12 465
    Points
    12 465
    Par défaut
    Salut,

    comment génères tu ton fichier Excel ??

  3. #3
    Débutant   Avatar de SonnyFab
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    498
    Détails du profil
    Informations personnelles :
    Âge : 34

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2010
    Messages : 498
    Points : 213
    Points
    213
    Par défaut
    A partir d'un repeater, au clic j'appelle cette fonction:
    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
    16
     Protected Sub Button2_Click(sender As Object, e As EventArgs)
     
    	Response.Clear()
    	Response.AddHeader("content-disposition", "attachment;filename=fichier.xls")
    	Response.Charset = ""
    	Response.ContentType = "application/vnd.xls"
    	Dim stringWrite As New System.IO.StringWriter()
    	Dim htmlWrite As System.Web.UI.HtmlTextWriter = New HtmlTextWriter(stringWrite)
    	MonRepeater.RenderControl(htmlWrite)
    	Response.Write(stringWrite.ToString())
    	Response.[End]()
    End Sub
     
    Public Overrides Sub VerifyRenderingInServerForm(control As Control)
     
    End Sub

  4. #4
    Débutant   Avatar de SonnyFab
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    498
    Détails du profil
    Informations personnelles :
    Âge : 34

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2010
    Messages : 498
    Points : 213
    Points
    213
    Par défaut
    J'admets que je ne comprends pas exactement le fonctionnement de cette fonction masi sa marche tant mieux, mais dois-je modifier le code ou dois-je créer une nouvelle fonction qui se chargera des cellules s'il vous plait?

  5. #5
    Expert confirmé
    Avatar de Nicolas Esprit
    Homme Profil pro
    Consultant en technologies
    Inscrit en
    Février 2010
    Messages
    1 467
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en technologies
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 1 467
    Points : 4 066
    Points
    4 066
    Par défaut
    Bonjour,

    L'astuce utilisée par ton code est de renvoyer uniquement l'HTML correspondant à ton repeater. Excel est capable de l'interpréter pour l'afficher comme un tableau.

    Maintenant, pour de la mise en forme plus spécifique, il va falloir utiliser les styles css.

    Tu as une illustration du concept ici (premier lien pris parmi d'autres, tu dois pouvoir trouver facilement un tuto complet sur le sujet via Google).

    En espérant t'avoir aidé.

  6. #6
    Débutant   Avatar de SonnyFab
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    498
    Détails du profil
    Informations personnelles :
    Âge : 34

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2010
    Messages : 498
    Points : 213
    Points
    213
    Par défaut
    Là j'ai pour un bon moment !
    Mais dis Nico j'ai un peu du mal à te suivre, c'est le css qui va dire sous quelle format dois être enregistrer le fichier excel?
    Je pensais que le css c'était juste pour la mise en forme.

    Sinon merci encore pour ce que vous faites Nico

  7. #7
    Débutant   Avatar de SonnyFab
    Étudiant
    Inscrit en
    Mai 2010
    Messages
    498
    Détails du profil
    Informations personnelles :
    Âge : 34

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2010
    Messages : 498
    Points : 213
    Points
    213
    Par défaut
    J'adore ce forum!!
    En sous titre on devrait écrire:
    Ne perdez jamais espoir !!!

    Merci Nico et surtout Enkel ce problème est résolu, et pour ceux qui auront le même problème voici le code:
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     Protected Sub ToExcel_Click(sender As Object, e As EventArgs)
     
        'On transforme chaque cellule du tableau en format "text" afin de pouvoir affiché les 0 non significatifs (à gauche) à l aide de la feuille de style'
    For i As Integer = 0 To monGV.Rows.Count - 1
         For j As Integer = 0 To monGV.Rows(i).Cells.Count - 1
              monGV.Rows(i).Cells(j).Attributes.Add("class", "vartochar")
         Next
    Next
     
    	Response.Clear()
    	Response.AddHeader("content-disposition", "attachment;filename=file.xls")
    	Response.Charset = ""
    	Response.ContentType = "application/vnd.xls"
    	Dim stringWrite As New System.IO.StringWriter()
    	Dim htmlWrite As System.Web.UI.HtmlTextWriter = New HtmlTextWriter(stringWrite)
    	' Transmission des données de la DataSet vers le HtmlTextWtriter'
    	monGV.RenderControl(htmlWrite)
    ' On applique la feuille de style'
    Dim style As String = "<style>.vartochar{mso-number-format:\@;text-align='center';}</style>"
    Response.Write(style)
     
    	Response.Write(stringWrite.ToString())
    	Response.[End]()
    end sub
     
     
       Public Overrides Sub VerifyRenderingInServerForm(control As Control)
     
    End Sub
    Je vous suis très reconnaissant!

    Merci encore

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

Discussions similaires

  1. Garder le format d'une cellule Excel
    Par peb12 dans le forum LabVIEW
    Réponses: 0
    Dernier message: 23/08/2011, 09h38
  2. Problème de format dans une cellule excel
    Par Nodoso dans le forum VB.NET
    Réponses: 6
    Dernier message: 13/12/2009, 18h26
  3. Modification du Format d'une Cellule Excel
    Par mehdiyou dans le forum VB.NET
    Réponses: 6
    Dernier message: 17/11/2009, 10h56
  4. Réponses: 1
    Dernier message: 19/04/2008, 22h39
  5. [VBA-E]changer le format d'une cellule dans un spreadsheet
    Par delamarque dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 13/02/2006, 11h12

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