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 :

formatage date avant envoi vers excel


Sujet :

ASP.NET

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Par défaut formatage date avant envoi vers excel
    Bonjour, j'ai un gridview que j'exporte vers Excel, mais la date apparaît au format mm/jj/aaaa et j'aimerais la forcer en aaaa-mm-jj lors de l'export sur excel. J'ai essayé d'utiliser un date.tostring ("yyyy-MM-dd") mais une fois les données exportées, sous excel, elles ne gardent pas ce format.
    Quelqu'un aurait une idée pour m'aider ?
    Merci d'avance.

  2. #2
    Expert confirmé

    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 : 47
    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
    Par défaut
    salut,

    quelle est la methode que tu utilise pour envoyer tes donnees dans excel ?

    Mon Blog

    The Cake is still a lie !!!



    Vous voulez contribuer à la rubrique .NET ? Contactez-moi par MP.
    Vous voulez rédiger des articles pour la rubrique .NET ? Voici la procédure à suivre.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Par défaut
    Voilà le code pour exporter vers 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
    16
    17
    18
    19
    20
    21
    22
    Public Function gridToExcel(ByVal myODS As ObjectDataSource, ByVal mygrid As GridView, ByVal myFilter As String, ByVal name As String) As Integer
            Response.Clear()
            Response.AddHeader("content-disposition", "attachment; filename=" + name + ".xls")
            Response.Charset = ""
            Response.ContentType = "application/vnd.ms-excel"
     
            Dim sw As System.IO.StringWriter = New System.IO.StringWriter()
            Dim htmw As System.Web.UI.HtmlTextWriter = New System.Web.UI.HtmlTextWriter(sw)
     
            sw.GetStringBuilder().Append("<H2>" + name + _
                                         "</H2><br>" + _
                                         Date.Now.ToShortDateString + "<br><br>")
            With mygrid
                .Visible = True
                myODS.FilterExpression = myFilter
                .DataBind()
                .RenderControl(htmw)
                .Visible = False
            End With
            Response.Write(sw.ToString)
            Response.End()
        End Function
    Pour situer mon niveau, j'ai commencé ASP VB il y a trois semaines surfant de forums en tutos sur le web. (d'ailleurs, merci Developpez.net !)

  4. #4
    Expert confirmé

    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 : 47
    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
    Par défaut
    Ok, alors je ne suis pas sur que tu puisse fraire grand chose...

    En fait, le formatage de ta date est guide par Excel, dans ce cas, tu lui passe un fichier html, qu'il interprete ensuite en excel.

    Si je me rappelle bien (mais je n'ai plus touche aux exports excel depuis un moment), le seul moyen de faire ce que tu veux serait de passer par de l'automation, ou de la generation au format excel-xml

    Mon Blog

    The Cake is still a lie !!!



    Vous voulez contribuer à la rubrique .NET ? Contactez-moi par MP.
    Vous voulez rédiger des articles pour la rubrique .NET ? Voici la procédure à suivre.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Juin 2009
    Messages : 11
    Par défaut
    Ok, merci pour la réponse, je tâcherai de regarder dans ces directions.

  6. #6
    Rédacteur/Modérateur
    Avatar de Skalp
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2006
    Messages
    1 694
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Développeur .NET

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 694
    Par défaut
    Citation Envoyé par xyanure Voir le message
    Bonjour, j'ai un gridview que j'exporte vers Excel, mais la date apparaît au format mm/jj/aaaa et j'aimerais la forcer en aaaa-mm-jj lors de l'export sur excel. J'ai essayé d'utiliser un date.tostring ("yyyy-MM-dd") mais une fois les données exportées, sous excel, elles ne gardent pas ce format.
    C'est Excel qui gère le format de la date. Quelque soit le format que tu passeras, si tu ne changes rien dans la présentation Excel, elle apparaitra toujours de la même façon (du moment que la date est valide).

    Citation Envoyé par Philippe Vialatte Voir le message
    Ok, alors je ne suis pas sur que tu puisse fraire grand chose...

    En fait, le formatage de ta date est guide par Excel, dans ce cas, tu lui passe un fichier html, qu'il interprete ensuite en excel.

    Si je me rappelle bien (mais je n'ai plus touche aux exports excel depuis un moment), le seul moyen de faire ce que tu veux serait de passer par de l'automation, ou de la generation au format excel-xml
    L'automation te permettrait de faire exactement ce que tu veux, en effet.
    Je n'en sais rien pour le format Excel-Xml.

    L'automation est assez lourde à mettre en place et il y a régulièrement des problèmes d'automation en ASP.Net assez complexes à résoudre (droits d'écriture du compte ASP.Net sur le serveur).

    Autre proposition : si la structure de ton GridView est fixe (nombre et type des colonnes qui ne change pas), tu pourrais créer un modèle de fichier Excel avec la présentation de la date qui va bien et tu l'alimenterais via ADO.Net (connexion OleDb).

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/12/2008, 10h13
  2. formatage colonne depuis oracle vers excel
    Par the_youpi dans le forum SQL
    Réponses: 3
    Dernier message: 23/10/2007, 19h37
  3. probleme d'envoi vers excel
    Par baboo50 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 31/07/2007, 17h42
  4. Format de date lors export vers Excel
    Par Celia1303 dans le forum Access
    Réponses: 7
    Dernier message: 19/12/2006, 07h23
  5. Envoie vers excel
    Par nah_wah dans le forum Composants VCL
    Réponses: 5
    Dernier message: 19/10/2005, 14h56

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