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

Bibliothèques et frameworks PHP Discussion :

[PEAR] Date avec utilisation de Spreadsheet excel writer


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Membre du Club
    Inscrit en
    Septembre 2006
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 65
    Points : 55
    Points
    55
    Par défaut [PEAR] Date avec utilisation de Spreadsheet excel writer
    Bonjour,

    Je fais un export depuis ma base Mysql grace à la classe pear "Spreadsheet excel writer".
    Jusqu'à présent, tout marche bien au niveau de l'extraction sauf que le fichier d'export prend les champs "date" comme "texte", ainsi on ne peut plus faire le tri sur une colonne date.
    Ce qui est assez curieux est que on ne peut pas changer le format cellule pour ces champs date sur ce fichier d'export.

    En effet, j'ai trouvé qq solutions possibles pour régler ce bug PEAR
    (veuillez voir le lien en dessous)

    http://bugs.pear.php.net/bugs/bug.php?id=3832

    Je trouve que le code de "Thierry Besancon" marche:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $dformat =& $workbook->addFormat();
    $dformat->setNumFormat('DD/MM/YYYY'); // french date format
    $worksheet->write($i,$j,"=DATEVALUE(\"1967-03-27\")", $dformat) ;
    Mais avec ce code-là, il y a un défaut:
    La champ date généré sera avec un petit triangle vert dans la case qui signifie d'un message d'erreur (formule non protégée!)

    Bon, je pose cette question ici et j'espère qu'il y aura qq'un qui peut me donner qq idées ou des meilleurs solutions, ou bien on peut réflechir ensemble.

    Merci par avance à vos attentions et vos aides futures!

  2. #2
    Membre du Club
    Inscrit en
    Septembre 2006
    Messages
    65
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 65
    Points : 55
    Points
    55
    Par défaut Résolu
    Bonjour,

    Bon j'ai trouvé:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    function date_to_excel($date) {
    	if (ereg("^([0-9]{1,2})/([0-9]{1,2})/([0-9]{2,4})$",$date,$t)) {
    		return ceil(strtotime("$t[2]/$t[1]/$t[3]")/60/60/24)+25569;
    	}
    	else return $date;
    }
    $fcelldate =& $xls->addFormat();
    $fcelldate->setNumFormat("DD/MM/YYYY");
    $sheet->write(6,6,date_to_excel("Date0"), $fcelldate);
    Grace à la fonction "date_to_excel", ça fonctionne nickel ! On peut faire du tri ou mettre un filtre.
    Mais il faut convertir le format date au moment d'exécuter la requête SQL:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT date_format(`la date à convertir`,'%d/%m/%Y') as Date0 ...
    Par exemple:
    la date à convertir="2007-10-07"
    donc Date0 sera ="07/10/2007"

    Bonne journée,

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [XL-2002] Affichage avec utilisation checkbox vba Excel
    Par couc86 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 21/04/2011, 15h04
  2. [PEAR] Utilisation de Excel Writer
    Par popovitch130 dans le forum Bibliothèques et frameworks
    Réponses: 9
    Dernier message: 08/12/2009, 11h25
  3. Réponses: 1
    Dernier message: 29/07/2008, 15h24
  4. [VBA]Utiliser les fonctions Excel avec Access
    Par PsykotropyK dans le forum VBA Access
    Réponses: 8
    Dernier message: 18/04/2007, 13h58
  5. [VB]Format de date avec excell
    Par Empty_body dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 16/02/2006, 14h56

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