Rechercher : dans
Par :

PHP vers excel

Dernière réponse le 24 mar 2009 à 12:36:27 Rhoda, le 27 jui 2004 à 17:35:19 
 Signaler ce message aux modérateurs

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

1

laxar, le 27 jui 2004 à 18:36:47
  • +2

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);

Répondre à laxar

2

cha, le 30 avr 2007 à 10:30:29

Bonjour,
Pourré tu maidé, je dois extraire les données de ma base Mysql vers un fichier excel ou cvs, mé je ne c pa comment my prendre...
Je ten remercie d'avance.

Répondre à cha

4

Pacap, le 29 jun 2007 à 09:06:09

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

Répondre à Pacap

3

isecso, le 9 mai 2007 à 11:53:53

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 .

Répondre à isecso

5

kenchi, le 6 jun 2008 à 17:33:48

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.

Répondre à kenchi

6

pmichaud, le 9 jun 2008 à 10:25:39

Bonjour
serait il possible d'avoir votre exemple, je vous remercie d'avance !

Répondre à pmichaud

7

kenchi, le 9 jun 2008 à 18:21:26

Bonjour,

ile me faut votre email pour t envoyeias le fichier zip avec exemple d'utilisation que j ai fais.ok

Répondre à kenchi

13

novfoot, le 29 aoû 2008 à 15:34:44

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.

Répondre à novfoot

8

men-of-fire, le 10 jun 2008 à 11:25:02
  • +1

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.

Répondre à men-of-fire

9

chocolatera, le 12 jun 2008 à 17:27:08

Salut,

moi aussi je suis entrain d'exporter une requette vers excel et j'ai utlisé l'objet COM le probleme c'est qu'il marche bien localment il me creer le fichier excel et exporte les donnés tres bien mais quant jé testé en ligne il m'a affiché ce jolie msg :( Class 'Com ' not fund
aider moi svp
merci

Répondre à chocolatera

10

men-of-fire, le 12 jun 2008 à 22:41:47

Bonsoir,

il se peux que ta oublier de mettre les classes et les bibiothéque avec les dossier de ton site web.

moi j ai jamais essayer de la mettre en ligne més je crois que c est mieux de travailler avec les bibiothéque de BiffWriter c est mieux et c est facile a exploiter.

Répondre à men-of-fire

11

chocolatera, le 23 jun 2008 à 10:07:32

Salut
ya pas de dossier a mettre juste tu instancier l'objet com et tu travaille avec ya pas d'autre fichier

Répondre à chocolatera

12

chocolatera, le 25 jun 2008 à 18:03:48

Salut
ya personne à me repondre??? :(

Répondre à chocolatera

14

 Anthe, le 24 mar 2009 à 12:36:27

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 ?

Répondre à Anthe
Collection CommentÇaMarche.net