Posez votre question Signaler

[PHP] Export Excel [Résolu]

sion76 26Messages postés 5 juillet 2009Date d'inscription - Dernière réponse le 17 déc. 2009 à 16:53
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
Lire la suite 

[PHP] Export Excel »

4 réponses
Réponse
+0
moins plus
Up! Y a plus personne sur le forum??
Ajouter un commentaire
Réponse
+0
moins plus
http://www.siteduzero.com/tutoriel-3-30907-generer-un-fichier-excel-via-php.html

Y a pas pour le format mais en trifouillant sur google tu devrais rapidement trouver, moi j'ai trouvé ce lien en 1 minute....
Ajouter un commentaire
Réponse
+0
moins plus
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)
Ajouter un commentaire
Réponse
+0
moins plus
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
Ajouter un commentaire
Ce document intitulé « [PHP] Export Excel » issu de CommentCaMarche (www.commentcamarche.net) est mis à disposition sous les termes de la licence Creative Commons. Vous pouvez copier, modifier des copies de cette page, dans les conditions fixées par la licence, tant que cette note apparaît clairement.
Dossier à la une
5 extensions si vous voulez revenir à l'ancien Facebook