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 :

DateTime et valeur "vide"


Sujet :

Langage PHP

  1. #1
    Membre expérimenté
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Points : 1 341
    Points
    1 341
    Par défaut DateTime et valeur "vide"
    Bonjour,

    Je suis entrain de me coder un système de traitement automatique de formulaires. Dans ces formulaires, j'ai des champs qui doivent être traités comme des dates.
    L'idée, c'est que quand je lis les variables de mon formulaire (je connais le type qu'elles doivent avoir), quand je tombe sur une variable de type date, je veux instancier un ODateTime (une classe perso qui étend DateTime). En cas de foirage (genre un utilisateur qui écrit n'importe quoi), la classe DateTime lève une exception.
    Jusque là, tout vas bien, mais pour un tas de raison pratique, j'aurai besoin d'un DateTime quand même. Du coup, naïvement, j'ai tenté de catcher pour lui donner la valeur 0000-00-00 (le "0" mysql).
    Mais là, ô surprise quand je l'affiche, j'obtiens : "-0001-11-30 00:00:00", ce qui est confirmé par la doc (voir les commentaires).

    Bref, est-ce que quelqu'un aurait une solution pour avoir un DateTime qui vaut "0000-00-00" ? Ou un équivalent ?

    Ps : voici ma classe ODateTime :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    class ODateTime extends DateTime {
    	public function ODateTime($init='now') {
    		try {
    			DateTime::__construct($init);
    		} catch (Exception $e) {
    			DateTime::__construct('0000-00-00');
    		}
    	}
     
    	public function __toString() {
    		return ($this->format('Y-m-d H:i:s'));
    	}
    }

  2. #2
    Membre émérite Avatar de Madfrix
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    2 326
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juin 2007
    Messages : 2 326
    Points : 2 566
    Points
    2 566
    Par défaut
    Bonjour,

    tu peux toujours faire un truc moche comme ca :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $date = new DateTime('0000-00-00');
    $date->modify('+32 day');
     
    // 0000-01-01 00:00:00
    echo $date->format('Y-m-d H:i:s');

  3. #3
    Membre expérimenté
    Avatar de Rakken
    Homme Profil pro
    Inscrit en
    Août 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 257
    Points : 1 341
    Points
    1 341
    Par défaut
    Au final, voilà ma classe. C'est pas terrible mais bon...
    L'idée sera de faire au moment de l'appel des tests du genre if (!$maClasse->estVide) pour éviter les valeurs incohérentes.

    Si jamais quelqu'un trouve une meilleure solution, je reste prenneur.

    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
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    <?php
    /**
     * Cette classe est une extension de la classe php DateTime, afin de lui rajouter certaines fonctionnalité,
     * notamment en terme de format d'affichage, et corriger des bug de php (ouin').
     */
     
    class ODateTime extends DateTime {
     
    	/**
    	 * Php n'est pas capable de générer correctement une date valant '0000-00-00 00:00:00'.
    	 * Pour compenser, cette rustine à été mise en place. Quand une date non viable est passée au
    	 * constructeur, estVide passe à true, __toString retourne la bonne valeur.
    	 * @var boolean
    	 */
    	private $_estVide = false;
     
    	/**
    	 * Constructeur de la classe.
    	 * @param String $init : facultatif, à "now" par défaut pour avoir le dateTime courant. Peut prendre une
    	 * date au format mysql (ex : 2004-03-20 01:06:00). Si une date invalide, vide ou commencant par 0000-00-00 est passée
    	 * alors estVide est passé à true.
    	 * Php bug sur la valeur 0000-00-00 donc il faut penser à tester estVide() avant de faire d'autres opérations
    	 * qu'un simple affichage (__toString) sous peine d'avoir des résultats incohérents.
    	 */
    	public function ODateTime($init='now') {
    		$init = trim($init);
    		try {
    			if (strncmp($init, '0000-00-00', 10) == 0 || empty($init)) {
    				$this->_estVide = true;
    				DateTime::__construct('0000-00-00');
    			} else {
    				$this->_estVide = false;
    				DateTime::__construct($init);
    			}
    		} catch (Exception $e) {
    			$this->_estVide = true;
    			DateTime::__construct('0000-00-00');
    		}
    	}
     
    	/**
    	 * Cette méthode est appelée quand DateTime est interprétée comme une chaine de caractères.
    	 * Le format retourné est celui de mysql.
    	 * @return String : la date au format mysql : 'Y-m-d H:i:s'
    	 */
    	public function __toString() {
    		if ($this->_estVide) {
    			return ('0000-00-00 00:00:00');
    		}
    		return ($this->format('Y-m-d H:i:s'));
    	}
     
    	/**
    	 * A cause d'un bug stupide de php, les DateTime ne savent pas gérer la date 0000-00-00. De fait, la valeur
    	 * vide passe par une variable interne "estVide". Avant de faire des opérations, si on a un doute sur la validité
    	 * de la date, il faut d'abord tester si estVide ne retourne pas true.
    	 * @return boolean : true si ce DateTime à été initialisé avec une valeur non valide, false sinon.
    	 */
    	public function estVide() {
    		return ($this->_estVide);
    	}
     
    	/**
    	 * Cette méthode statique prend une date au format jj/mm/aaaa et la transforme au format aaaa-mm-jj qui est lisible
    	 * directement par mysql.
    	 * @param string $date : une date de la forme jj/mm/aaaa. Si ce format n'est pas respecté, la date retournée est
    	 * 0000-00-00
    	 * @return string : la date avec le nouveau format
    	 */
    	static public function reformateDateSql($date) {
    		@list($jour, $mois, $annee) = explode ('/', $date, 3);
    		if (empty($jour) || empty($mois) || empty($annee)) {
    			return ('0000-00-00');
    		} else {
    			return ($annee . '-' . $mois . '-' . $jour);
    		}
    	}
     
    }
     
    ?>

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