IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

Class ' PHPExcel_IOFactory' not found


Sujet :

Langage PHP

  1. #1
    Membre confirmé Avatar de a028762
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 419
    Points : 537
    Points
    537
    Par défaut 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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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 : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    require_once 'PHPExcel/IOFactory.php';
    $Type = PHPExcel_IOFactory::identify($FichierExcel);
    Là, sur la dernière ligne, j'ai le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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

  2. #2
    Membre confirmé Avatar de a028762
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 419
    Points : 537
    Points
    537
    Par défaut 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 : Sélectionner tout - Visualiser dans une fenêtre à part
    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 ...
    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 ?

Discussions similaires

  1. [2.x] class 'PHPExcel_IOFactory' not found
    Par blacksf dans le forum Symfony
    Réponses: 1
    Dernier message: 14/12/2012, 13h48
  2. [Zip] Class ZipArchive not found
    Par Sayrus dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 07/06/2007, 16h04
  3. classe .cls not found
    Par iznogoud36 dans le forum Erreurs - Avertissements
    Réponses: 1
    Dernier message: 07/03/2007, 23h55
  4. Réponses: 1
    Dernier message: 09/02/2007, 14h59
  5. [TOMCAT 5.0 - JSP] Load: class XXX not found
    Par Hoegaarden dans le forum Tomcat et TomEE
    Réponses: 12
    Dernier message: 20/10/2005, 09h59

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo