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

Langage PHP Discussion :

Générer un fichier xls (pas csv) sur php


Sujet :

Langage PHP

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    27
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 27
    Points : 28
    Points
    28
    Par défaut Générer un fichier xls (pas csv) sur php
    Bonjour,

    je voudrais savoir comment générer un fichier xls (pas csv) sur php. est ce qu'il y a des moyens pour faire? header information, séparation de colonne..??

    merci

  2. #2
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Bonjour,

    voici un exemple simple qui génère un fichier xls :

    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
    <?php
     
    // Premiere ligne = nom des champs. (\t) sert à passer d'une cellule à une autre dans excel
    $csv_output = "nom_champ1\tnom_champ2\tnom_champ3";
    $csv_output .= "\n";
     
    $query = "La requête";
     
            $result = mysql_query($query)
            or die('Erreur SQL !<br />' . $query . '<br />' . mysql_error());
     
            //Boucle sur les resultats :
            while($row = mysql_fetch_array($result)) {
                $csv_output .= "$row[champ1]\t$row[champ2]\t$row[champ3]\n"; // \t: sert à passer d'une cellule à une autre pour excel
            }
     
            header("Content-type: application/vnd.ms-excel");
            header("Content-disposition: attachment; filename=Export_" . date("d-m-Y").".xls");
            print $csv_output;
            exit;
    ?>

  3. #3
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    Citation Envoyé par arthuro45 Voir le message
    Bonjour,

    voici un exemple simple qui génère un fichier xls :

    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
    <?php
     
    // Premiere ligne = nom des champs. (\t) sert à passer d'une cellule à une autre dans excel
    $csv_output = "nom_champ1\tnom_champ2\tnom_champ3";
    $csv_output .= "\n";
     
    $query = "La requête";
     
            $result = mysql_query($query)
            or die('Erreur SQL !<br />' . $query . '<br />' . mysql_error());
     
            //Boucle sur les resultats :
            while($row = mysql_fetch_array($result)) {
                $csv_output .= "$row[champ1]\t$row[champ2]\t$row[champ3]\n"; // \t: sert à passer d'une cellule à une autre pour excel
            }
     
            header("Content-type: application/vnd.ms-excel");
            header("Content-disposition: attachment; filename=Export_" . date("d-m-Y").".xls");
            print $csv_output;
            exit;
    ?>
    c'est un CSV ça ...
    en plsu c'est pas le bonne méthode pour en créer un

  4. #4
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Autant utiliser les bons outils (enfin presque)

  5. #5
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Pour une fois que je pensais pouvoir aider quelqu'un, c'est raté

    c'est un CSV ça
    Chez moi ça génère un xls basique certe, mais .xls reconnu comme tel par Excel.

  6. #6
    Membre émérite
    Avatar de gene69
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    1 769
    Détails du profil
    Informations personnelles :
    Localisation : France

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

    Informations forums :
    Inscription : Janvier 2006
    Messages : 1 769
    Points : 2 446
    Points
    2 446
    Par défaut
    non c'est parce que tu travailles avec windows et que windows fait confiance aux extensions.

    Ouvre un vrai xls créé avec excel et ton fichier dans un éditeur de texte (notepad...) tu verras la différence.
    PHP fait nativement la validation d'adresse électronique .
    Celui qui a inventé mysql_connect(...) or die() est déjà mort plusieurs fois.

    Utilisez le bouton résolu!

  7. #7
    Membre actif Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Points : 265
    Points
    265
    Par défaut
    Ouvre un vrai xls créé avec excel et ton fichier dans un éditeur de texte (notepad...) tu verras la différence.
    Dans notepad :
    Effectivement, avec un xls généré par Excel j'ai des caractères illisibles, ce qui semble normal, tandis qu'avec un xls généré par mon script tout est lisible.

  8. #8
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    Citation Envoyé par arthuro45 Voir le message
    Dans notepad :
    Effectivement, avec un xls généré par Excel j'ai des caractères illisibles, ce qui semble normal, tandis qu'avec un xls généré par mon script tout est lisible.
    et pour creer un csv c'est avec fputcsv

Discussions similaires

  1. Conversion de fichier xls en csv via php
    Par Realniggaz dans le forum Langage
    Réponses: 1
    Dernier message: 05/06/2013, 15h31
  2. Générer un fichier word ou excel en php
    Par Taz_8626 dans le forum Bibliothèques et frameworks
    Réponses: 10
    Dernier message: 10/05/2011, 09h57
  3. Convertir un fichier XLS en CSV
    Par n@n¤u dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 24/07/2006, 12h57
  4. Réponses: 7
    Dernier message: 29/06/2006, 12h33
  5. [Excel] Convertir un fichier xls en csv sous UNIX
    Par Tsuful dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 14/04/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