Posez votre question Signaler

PHP vers excel

Rhoda - Dernière réponse le 12 août 2010 à 14:27
Bonjour,

je travaille avec easyphp 1.7 et je souhaiterais afficher les resultats de requete sur une feuille excel. Sur le net, j'ai trouvé un outil xls magique qui fait ce transfert mais malheureusement ça ne marche que pour easyphp 1.5 et 1.6. Pourriez vous m'indiquer des outils à utiliser et n'oubliez pas d'indiquer briévement le mode d'utilisation. merci
Lire la suite 

PHP vers excel »

18 réponses
Réponse
+3
moins plus
Voila l'exemple et il vous vous les bibiothéaue de la classe BiffWriter.

Si t'en a pas trouvé ces bibiothéque laisse moi ton e-mail pour te les envoyées.

cette exemple marche 100% je l'ai bien téster dans mon application et ca marche a mervielle.

et si il ya un probléme contact moi.


<?php

require_once('Spreadsheet\\Excel\\Writer\\BIFFwriter.php');
require_once('Spreadsheet\\Excel\\Writer\\Worksheet.php');
require_once('Spreadsheet\\Excel\\Writer\\Workbook.php');function HeaderingExcel($filename) {
header("Content-type: application/vnd.ms-excel");
header("Content-Disposition: attachment; filename=$filename" );
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0,pre-check=0");
header("Pragma: public");
}// HTTP headers
HeaderingExcel('test.xls');// Creating a workbook
$workbook = new Spreadsheet_Excel_Writer_Workbook("-");
$t=& $workbook->addformat();
$t->setSize(16);
$t->setAlign('center');
$t->setColor('red');
$t->setPattern();


$title=& $workbook->addformat();
$title->setSize(12);
$title->setAlign('center');
$title->setColor('white');
$title->setPattern();
$title->setBgColor('dark');
$fh=& $workbook->addformat();
$fh->setSize(10);
$fh->setAlign('center');
$fh->setColor('red');
$fh->setPattern();
$fh->setBgColor('white');
// 1ere feille
$worksheet1 =& $workbook->addworksheet('Liste Tous Les Clients');
$worksheet1->write(3,4,"Liste De Tous Les Clients",$t);
$worksheet1->write(5, 2, "Num Client",$fh);
$worksheet1->write(5, 3, "Nom Client",$fh);
$worksheet1->write(5, 4, "Prenom Client",$fh);
$worksheet1->write(5, 5, "Date Naissance",$fh);
$worksheet1->write(5, 6, "ville",$fh);
$bitmap="Sans titre.bmp";
$worksheet1->insertBitmap(10, 10, $bitmap, $x = 0, $y = 0, $scale_x = 1, $scale_y = 1);
$worksheet1->_positionImage(10, 10, 10, 10, 480, 359);
$link=mysql_connect('localhost','root','');
$db=mysql_select_db('gestion_client');
if(isset($_GET['id'])){
$sql=$_GET['id'];
}
$res=mysql_query($sql);
$num=mysql_num_rows($res);

if($res){

while($row=mysql_fetch_row($res)){

//pour positionner les donnée dans la feuille
static $x1=6;
static $y1=2;
$worksheet1->write($x1, $y1, "".$row[0],$title);
$worksheet1->write($x1, $y1+1, "".$row[1],$title);
$worksheet1->write($x1, $y1+2, "".$row[2],$title);
$worksheet1->write($x1, $y1+3, "".$row[3],$title);
$worksheet1->write($x1, $y1+4, "".$row[4],$title);
$y1=2;
$x1=$x1+1;
}
}

//2emme fieulle
$worksheet2 =& $workbook->addworksheet('Rabat');
$worksheet2->write(3,4,"Liste De Tous Les Clt De Rabat.",$t);
$worksheet2->write(5, 2, "Num Client",$fh);
$worksheet2->write(5, 3, "Nom Client",$fh);
$worksheet2->write(5, 4, "Prenom Client",$fh);
$worksheet2->write(5, 5, "Date Naissance",$fh);
$worksheet2->write(5, 6, "ville",$fh);

$req="select * from client where ville='rabat'";
$res=mysql_query($req);
$num=mysql_num_rows($res);

if($res){

while($row=mysql_fetch_row($res)){
static $x2=6;
static $y2=2;
$worksheet2->write($x2, $y2, "".$row[0],$title);
$worksheet2->write($x2, $y2+1, "".$row[1],$title);
$worksheet2->write($x2, $y2+2, "".$row[2],$title);
$worksheet2->write($x2, $y2+3, "".$row[3],$title);
$worksheet2->write($x2, $y2+4, "".$row[4],$title);
$y2=2;
$x2=$x2+1;
}
}
//3emme fieulle
$worksheet3 =& $workbook->addworksheet('casa');
$worksheet3->write(3,4,"Liste De Tous Les Clt De Casa.",$t);
$worksheet3->write(5, 2, "Num Client",$fh);
$worksheet3->write(5, 3, "Nom Client",$fh);
$worksheet3->write(5, 4, "Prenom Client",$fh);
$worksheet3->write(5, 5, "Date Naissance",$fh);
$worksheet3->write(5, 6, "ville",$fh);

$query="select * from client where ville='casa'";
$res=mysql_query($query);
$num=mysql_num_rows($res);

if($res){

while($row=mysql_fetch_row($res)){
static $x3=6;
static $y3=2;
$worksheet3->write($x3, $y3, "".$row[0],$title);
$worksheet3->write($x3, $y3+1, "".$row[1],$title);
$worksheet3->write($x3, $y3+2, "".$row[2],$title);
$worksheet3->write($x3, $y3+3, "".$row[3],$title);
$worksheet3->write($x3, $y3+4, "".$row[4],$title);
$y3=2;
$x3=$x3+1;
}
}
//4emme fieulle
$worksheet4 =& $workbook->addworksheet('sale');
$worksheet4->write(3,4,"Liste De Tous Les Clt De Sale. ",$t);
$worksheet4->write(5, 2, "Num Client",$fh);
$worksheet4->write(5, 3, "Nom Client",$fh);
$worksheet4->write(5, 4, "Prenom Client",$fh);
$worksheet4->write(5, 5, "Date Naissance",$fh);
$worksheet4->write(5, 6, "ville",$fh);
$ql="select * from client where ville='sale'";
$res=mysql_query($ql);
$num=mysql_num_rows($res);

if($res){

while($row=mysql_fetch_row($res)){
static $x4=6;
static $y4=2;
$worksheet4->write($x4, $y4, "".$row[0],$title);
$worksheet4->write($x4, $y4+1, "".$row[1],$title);
$worksheet4->write($x4, $y4+2, "".$row[2],$title);
$worksheet4->write($x4, $y4+3, "".$row[3],$title);
$worksheet4->write($x4, $y4+4, "".$row[4],$title);
$y4=2;
$x4=$x4+1;
}
}

$workbook->close();
?>


j'éspére que ca vous aidra.

Coordialement.

c'est moi kenchi le vogaband.
chocolatera - 23 juin 2008 à 10:07
salut
ya pas de dossier a mettre juste tu instancier l'objet com et tu travaille avec ya pas d'autre fichier
chocolatera - 25 juin 2008 à 18:03
salut
ya personne à me repondre??? :(
Jine - 26 avril 2010 à 08:23
Si j'ai bien compris l'exemple de Laxar utilise l'objet com, utilisable uniquement sous les serveurs utilisant Win32, le second utilise la méthode sylk indépendante de la plateforme. La seconde méthode avec les classe BiffWriter semble être portable et donc plus intéressante à mon avis.
Ajouter un commentaire
Réponse
+1
moins plus
Bon ben je vais te donner ce code qui te permettra d'ouvrir un fichier excel existant (j'ai aussi la version où tu le crèes toi meme), d'activer la feuille sur la quelle tu veux écrire et d'écrire une variable "php" dans une case donnée. Tu as surement des tableaux alors tu pourras faire tout simplemlent une boucle "for" dessus.
$FILENAME="C:\FichExcel.xls";
$excel=new COM("Excel.application");
$excel->Workbooks->Open($FILENAME);
//$excel->Visible=1;
$book=$excel->Workbooks(1);
$sheet=$book->Worksheets(1);

//là tu peux faire ta boucle for
$selcell = $sheet->cells(NumLigne,NumColonne);
$selcell->activate;
$selcell->value=$variable;

$book->Save();
unset($sheet);
unset($book);
$excel->Workbooks->Close();
$excel->Quit();
unset($excel);
Pacap - 29 juin 2007 à 09:06
Bonjour laxar,
Tout dabord ton code marche super bien, seulement ce code fonctionne que lorsque le fichier est déjà créé.
Car j'ai essayer de faire :

$FILENAME = "C:\\htdocs\\dev\\mag6\\".$nom.".xls";

Et ca marche pas.

Mais avant ton code tu dit que tu as la version permettant de créer soi-même le fichier excel, ce qui serait très pratique pour une génération dynamique du nom du fichier. Donc si tu as moyen de me donner la version de création du fichier excel, ou de me dire ou trouver l'information car je ne trouve nul-part ailleur.

Merci
shadow - 30 avril 2010 à 15:26
mersi ton aide m'as bcp aider
mosantu - 12 août 2010 à 14:27
Merci bcp pour ton code. il marche tres bien, mais seulement avec office 2003. sous office 2007, ca ne marche pas. as tu réussi a palier a cela
Ajouter un commentaire
Réponse
+0
moins plus
salut,
si vous avez besoin du code pour générer des fieulle d'xel et méme avec plusier classeurs vous n'avez ka me contacter pour te donner un exemple que j ai réaliser pour vous aidez.
pmichaud - 9 juin 2008 à 10:25
Bonjour
serait il possible d'avoir votre exemple, je vous remercie d'avance !
kenchi - 9 juin 2008 à 18:21
bonjour,

ile me faut votre email pour t envoyeias le fichier zip avec exemple d'utilisation que j ai fais.ok
novfoot - 29 août 2008 à 15:34
Bonjour,

Je suis très intéressé par un exemple pour créer un fichier excel avec plusieurs onglet en php.
J'ai fait un essai avec l'objet COM mais j'ai quelques soucis et je ne sais pas comment faire pour afficher le résultat directement dans une page internet (sous IE6).

C'est assez urgent.

D'avance Merci.
Ajouter un commentaire
Réponse
+0
moins plus
J'ai essayé l'exemple laissé par men-of-fire. ça me donne une page blanche ..

Quelqu'un aurait-il un code véritablement fonctionnel ?
guelbe - 14 déc. 2009 à 10:09
est ce que tu as désactivé ton fire-wall ?
Ajouter un commentaire
Réponse
-1
moins plus
salut tous
si vous avez une réponce à un exportation des données d'une base Oracle vers EXcel via php merci de l'envoyer à ce mail atefbic83@yahoo.fr et merci d'avances .
Ajouter un commentaire
Ce document intitulé « PHP vers 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
Windows 8 - À quoi s'attendre ?