[PHP] Export Excel

Résolu
sion76 Messages postés 28 Statut Membre -  
320C Messages postés 101 Statut Membre -
Bonjour,
j'exporte un tableau créé à partir de requêtes SQL dans un fichier excel (qui n'existe pas encore). Tout se passe niquel, bien rangé en colonnes avec entêtes etc. Le problème c'est le format de mes colonnes. J'en ai une où la donnée est du genre 12000012324564123456. Donc il me le simplifie en affichant 1,20000+18 . Je sais régler ce problème manuellement sur Excel (quand même :p) mais ce que je voudrais arriver à paramétrer, c'est le format des données et des colonnes (la largeur de la colonne et le format du nombre précisément).

J'utilise la méthode header pour mon export. Quelqu'un pourrait-il me conseiller? Merci
Configuration: Windows XP Internet Explorer 7.0

4 réponses

  1. sion76 Messages postés 28 Statut Membre 1
     
    Up! Y a plus personne sur le forum??
    1
  2. sion76 Messages postés 28 Statut Membre 1
     
    Merci c'est sympa. Le problème de leur méthode, c'est qu'eux n'utilisent pas vraiment de bdd, et mes header marchent si bien avec ma bdd que j'hésite un peu à changer de méthode (surtout quand je vois leurs boucles) enfin bon, je suis peut être un peu faignant, je vais regarder ça de plus près, merci encore!

    (mais si quelqu'un à la solution pour l'autofit des colonnes avec la méthode header je prends toujours :p)
    0
  3. guelbe
     
    Bonjour,
    peux tu montrer ton code car je trouve des problemes pour la fonction saveas
    voici mon code:

    $chemin_act = getcwd();

    // On définie une constante FILENAME comprenant le nom du fichier à générer et son emplacement.
    define("FILENAMEREC",$chemin_act."\recettes.xls");

    if(file_exists(FILENAMEREC)) // On vérifie que le fichier existe.
    {
    unlink(FILENAMEREC); // Suppression du fichier précédemment créé s'il existe.
    }

    $excel=new COM("Excel.application"); //Instanciation de l'objet COM
    $excel->sheetsinnewworkbook=1;//1 seule feuille de calcul dans le document
    $excel->Workbooks->Add();//Ajout d'un classeur
    $book=$excel->Workbooks(1);//$book contient le classeur actif
    $sheet=$book->Worksheets(1);//$sheet contient la feuille active (comme son nom l'indique, feuille en anglais)
    $sheet->Name="stati";//Attribution d'un nom à la feuille

    $cell=$sheet->Range('A1');
    $cell->value='TRIMESTRE'; //Titre de mes colonnes
    $cell->EntireColumn->AutoFit;
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('B1');
    $cell->EntireColumn->AutoFit; // La largeur de la colonne s'adapte en fonction de l'intérieur de la cellule
    $cell->value='T-1'; //Nombre de questions qu'on a posées
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('C1');
    $cell->EntireColumn->AutoFit; // La largeur de la colonne s'adapte en fonction de l'intérieur de la cellule
    $cell->value='T-2'; //Nombre de questions qu'on a posées
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('D1');
    $cell->EntireColumn->AutoFit; // La largeur de la colonne s'adapte en fonction de l'intérieur de la cellule
    $cell->value='T-3'; //Nombre de questions qu'on a posées
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('E1');
    $cell->EntireColumn->AutoFit; // La largeur de la colonne s'adapte en fonction de l'intérieur de la cellule
    $cell->value='T-4'; //Nombre de questions qu'on a posées
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('A2');
    $cell->value= 'Privé & Semi-Public';
    $cell->EntireColumn->AutoFit;
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('A3');
    $cell->value= 'Public';
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $cell=$sheet->Range('A4');
    $cell->value= 'Université';
    $cell->Font->bold = true; //Met en gras le texte (bold)

    $trimestre = "BCDE";
    $lg_priv_sp = 2;
    $lg_pub = 3;
    $lg_univ = 4;

    for($i=0; $i<4; $i++)
    {
    $cell=$sheet->Range($trimestre[$i].$lg_priv_sp);
    $cell->value= $som_com[$i];

    $cell=$sheet->Range($trimestre[$i].$lg_pub);
    $cell->value= $som_adm[$i];

    $cell=$sheet->Range($trimestre[$i].$lg_univ);
    $cell->value= $som_univ[$i];

    } // for($i=0; $i<4; $i++)

    $book->saveas(FILENAMEREC);//Sauvegarde du fichier
    unset($sheet);//Libération de $sheet
    unset($book);//Libération de $book
    $excel->Workbooks->Close();//Fermeture du classeur
    $excel->Quit();//On quitte Excel
    unset($excel);//Libération de l'instance $excel
    0
    1. 320C Messages postés 101 Statut Membre
       
      Salut
      Il y a aussi cette préoccupation qui me dérange, si vous voudriez bien m'indiquer comment faire pour générer aussi un fichier excel à partir d'un tableau en html
      et mon soucis et si tu voudrais bien me faire connaissance de cela, est de faire cette exportation

      Merci pour ton aide guelbe
      0