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

PHP & Base de données Discussion :

Code php pour exporter les données mysql sous Excel


Sujet :

PHP & Base de données

  1. #1
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2011
    Messages : 7
    Points : 15
    Points
    15
    Par défaut Code php pour exporter les données mysql sous Excel
    Bonjour, j'aimerais un code PHP qui va me permettre d'exporter les données mysql de mon serveur web sous Excel.le code ci-dessous ne marche que sur mon serveur local.

    Voici mon 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
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    header('Content-Type: application/vnd.ms-excel');
    header('Content-Disposition: attachment;filename="01simple.xls"');
    header('Cache-Control: max-age=0');
     
    //connexion à la base de données
     
    include('../../access2.php');
     
    //Lancement de la requete
    $req = "SELECT * FROM cdc,sous_projet_ic WHERE cdc.cod_cdc=sous_projet_ic.cod_cdc AND sp_soumis='Oui' ORDER BY annee_soumis DESC, mois_soumis DESC, jour_soumis DESC ";
    $resultat = mysql_query($req) or die('Erreur SQL !'.$req.''.mysql_error());
     
     
    echo'<div align="center">
    <table border="2" cellspacing="2" cellpadding="5" bordercolor="#999999">
    <tr><td align="center" colspan="6" bgcolor="#FFCC99">LISTE DES SOUS PROJETS SOUMIS INFRASTRUCTURE COMMUNAUTAIRE</td></tr>
    <tr>
    <td width="200" align="center" bgcolor="#DDD"><strong>LOCALISATION</strong></td>
    <td width="180" bgcolor="#DDD"><strong>CODE DU CDC</strong></td>
    <td width="154" bgcolor="#DDD"><strong>NOM DU CDC</strong></td>
    <td width="200" align="center" bgcolor="#DDD"><strong>CODE DU
    SOUS PROJET</strong></td>
    <td width="320" align="center" bgcolor="#DDD"><strong>TITRE DU
    SOUS PROJET</strong></td>
    <td width="100" align="center" bgcolor="#DDD"><strong>DATE DE
    SOUMISSION</strong></td>
    <!--<td width="110" align="center" bgcolor="#DDD"><strong>OPERATION</strong></td>-->';
    while($data = mysql_fetch_array($resultat))
    {
    echo'
    <tr>
    <td bgcolor="#EDEDED" align="center">';
     
    $sel = "SELECT * FROM departement WHERE cod_dep ='".$data['cod_dep']."'";
    $res = mysql_query($sel) or die('Erreur SQL !'.$sel.'
    '.mysql_error());
    while($dat = mysql_fetch_array($res))
    {
    echo strtoupper($dat['lib_dep']);
    }
     
    $sel = "SELECT * FROM sous_prefecture WHERE cod_soupref ='".$data['cod_soupref']."'";
    $res = mysql_query($sel) or die('Erreur SQL !'.$sel.'
    '.mysql_error());
    while($dat = mysql_fetch_array($res))
    {
    echo ' / '.strtoupper($dat['lib_soupref']);
    }
    echo'</td>
     
    <td bgcolor="#EDEDED">'.$data['cod_cdc'].'</td>
    <td bgcolor="#EDEDED">';
    $sel = "SELECT * FROM cdc WHERE cod_cdc ='".$data['cod_cdc']."'";
    $res = mysql_query($sel) or die('Erreur SQL !'.$sel.'
    '.mysql_error());
    while($dat = mysql_fetch_array($res))
    {
    echo strtoupper(stripslashes($dat['nom_cdc']));
    }
    echo'</td>
    <td align="center" bgcolor="#EDEDED">'.strtoupper($data['cod_sp']).'</td>
    <td align="center" bgcolor="#EDEDED">'.strtoupper(stripslashes($data['titre_sp'])).'</td>
    <td align="center" bgcolor="#EDEDED">'.strtoupper($data['date_soumis']).'</td>
     
    </tr>';
    }
    echo'</table><p> &nbsp; </p>';
     
    echo'</div>';

  2. #2
    Expert confirmé
    Avatar de TiranusKBX
    Homme Profil pro
    Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Inscrit en
    Avril 2013
    Messages
    1 476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 476
    Points : 4 805
    Points
    4 805
    Billets dans le blog
    6
    Par défaut
    excel n'interprète pas de code HTML
    tu à plus de chance qu'i te le lise au format csv encodé en ANSI
    Rien, je n'ai plus rien de pertinent à ajouter

  3. #3
    Membre à l'essai
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2011
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Côte d'Ivoire

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Août 2011
    Messages : 7
    Points : 15
    Points
    15
    Par défaut Code php pour exporter les données mysql sous Excel
    Puis-je avoir un code pour le tester

  4. #4
    Expert confirmé
    Avatar de TiranusKBX
    Homme Profil pro
    Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Inscrit en
    Avril 2013
    Messages
    1 476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 476
    Points : 4 805
    Points
    4 805
    Billets dans le blog
    6
    Par défaut
    pour faire du CSV c'est simple
    la première ligne contiens tes noms de colonnes
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    echo '"Col_1";"Col_2";"Col_3";"Col_4";"Col_5"'.PHP_EOL;
    echo '"val1";0;4;;5'.PHP_EOL;

    toutes les colonnes doivent être séparées par des ;
    à la suite si tu a une colonne vide met tout de même le ; (comme ici en colonne 4) et les textes entourés de "
    /!\ pour les valeur numérique en format de chaîne (exemple numéros de téléphone) excel auras tendance à te virer les 0 initiaux
    donc mettre un caractère non numérique(y compris +,-,/,*) au début ou dedans règle le problème
    Rien, je n'ai plus rien de pertinent à ajouter

  5. #5
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Points : 16 372
    Points
    16 372
    Par défaut
    Le CSV est un bon compromis, mais il ya plus propre pour le construire : PHP fournit des fonctions pour gérer le CSV, notamment fputcsv qui permet d'écrire des lignes au format CSV dans un fichier.
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  6. #6
    Expert confirmé
    Avatar de TiranusKBX
    Homme Profil pro
    Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Inscrit en
    Avril 2013
    Messages
    1 476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur C, C++, C#, Python, PHP, HTML, JS, Laravel, Vue.js
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 1 476
    Points : 4 805
    Points
    4 805
    Billets dans le blog
    6
    Par défaut
    ho je l'avait oubliée celle-là vus qu'en général je génère du json ou xml
    Rien, je n'ai plus rien de pertinent à ajouter

Discussions similaires

  1. Probléme pour exporter les données BD vers word sous format tableau
    Par farfarawi dans le forum Développement Windows
    Réponses: 1
    Dernier message: 21/03/2014, 01h48
  2. code php pour afficher les dernier article
    Par sousse92 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 2
    Dernier message: 04/03/2013, 23h40
  3. Réponses: 1
    Dernier message: 09/01/2012, 14h49
  4. Réponses: 10
    Dernier message: 07/07/2010, 15h01
  5. [XL-2003] adresse variable pour importer les données txt sous excel
    Par renfei1984 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 02/07/2010, 10h29

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