Class ' PHPExcel_IOFactory' not found
Bonjour
je travaille avec la bibliothèque PHPExcel avec Php en Version 5.5.9-1ubuntu4.3, (ou Windows 7, mais c'est le même problème)
j'utilise ses fonctions en mode classique, avec des syntaxes "traditionnelles"
Code:
1 2
| require_once 'PHPExcel/Writer/Excel5.php';
$Lecteur = new PHPExcel_Reader_Excel5(); |
l'include du php.ini pointe vers le répertoire au dessus de PHPExcel (comme prévu dans la doc)
Code:
include_path = ".;\Public\racine\phpexcel\Classes;...."
Cette bibliothèque offre par ailleurs une possibilité d'une ouverture plus souple des fichiers excel, IOFactory
Mais la mise en oeuvre est différente, par l'utilisation de méthode statique ...
Code:
1 2
| require_once 'PHPExcel/IOFactory.php';
$Type = PHPExcel_IOFactory::identify($FichierExcel); |
Là, sur la dernière ligne, j'ai le message
Code:
Class ' PHPExcel_IOFactory' not found
alors que le fichier de déclaration de la classe est juste au dessus et ne provoque pas d'erreur lors du require
Quelqu'un sait utiliser cette classe ?
En regardant le code de cette bibliothèque, les exemples fonctionnent sur cette syntaxe, mais dans l'arborescence de la bibliothèque, pas dans mon code.
le problème (semble-t-il) viendrait du côté de la gestion des autoload (spl) ?
J'avoue être un peu désarçonné devant ce problème
Olivier
Pour tenter d'avancer ...
J'ai écris le code qui se rapproche le plus de ce que j'intègre dans mon framework
en fait la fonction est dans une classe appelée ... contrairement à l'extrait ci-dessous (qui provoque le même problème)
Code:
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
| <?php
define (br,"<br />");
$FichierExcel = 'example1.xls';
list($Classeur,$Message) = OuvrirLecture($FichierExcel);
echo $Message.br;
# =================================================================== Ouvrir un classeur en LECTURE (avec load générique)
function OuvrirLecture($FichierExcel) {
# $FichierExcel Chemin complet du fichier EXCEL à lire (absolu ? ca doit marcher aussi pour le relatif)
# $Onglets [option] Tableau des NOMS des onglets à lire
# --------------------------------------------------------------- Contrôle du fichier d'entrée
$NomFichier = basename($FichierExcel);
if (!file_exists($FichierExcel)) {
$Message = "le fichier '".$NomFichier."' n'existe pas ";
} else {
echo get_include_path().br;
require_once 'PHPExcel/IOFactory.php';
$Type = PHPExcel_IOFactory::identify($FichierExcel); # Identify the type of $FichierExcel
echo "Type:".$Type."!".br;
$Lecteur = PHPExcel_IOFactory::createReader($Type); # Create a new Reader of the type that has been identified
echo br;
$Classeur = $Lecteur->load($FichierExcel); # Load $FichierExcel to a PHPExcel Object
$Classeur->setReadDataOnly(true); # Plus rapide 108 à 18 secondes !!!
# --------------------------------------------------------------- Analyse des entrées
if (func_num_args() > 1) {
$Onglets = func_get_arg(1);
} else {
$Onglets = array();
}
if (!is_array($Onglets)) {
$Message = "La liste des onglets à ouvrir doit être un tableau";
} else {
if (sizeof($Onglets) > 0) { # Si la liste des onglets cherchée est connue ! c'est encore plus rapide
$Classeur->setLoadSheetsOnly($Onglets); # Plus rapide 18 à 6 secondes ?
} else {
$Classeur->setLoadAllSheets();
}
}
}
return array($Classeur,$Message);
} |
et là, l'erreur est ...
Citation:
Fatal error: Class 'PHPExcel_Reader_' not found in D:\Public\racine\PhpExcel_1.8.0\Classes\PHPExcel\IOFactory.php on line 170
Donc en interne de la bilothèque ... curieux non ?