Retourne d'une date littérale la date exacte

La fonction permet de préciser une date du type "mardi prochain" ou "hier" en "17 octobre" par exemple. 
Pour éviter de se lancer dans de gros calculs... 
Pour plus de précision sur les paramètres voir le code. 
Auteur : Pierre Beaumadier


Information sur les mises à jour

Dernière mise à jour :

30 Août 2019
fonctionnement du code vérifié
correction du code

1 910  vues
Compatibilité du code
PHP 5, PHP 7 et PHP 8
  code classé dans   Dates - Heures
  code source classé dans   Dates - Heures
 
01
02
03
04
05
06
07
08
09
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
                    
<?php
/*------------------------------*/
/*
Titre : Retourne d'une date littérale la date exacte

Date édition : 15 Fev 2019
Date mise a jour : 30 Aout 2019

Rapport de la maj:
- fonctionnement du code vérifié
- correction du code
*/
/*------------------------------*/

function what_day_is($day){
// valeurs possibles pour $day : celles du tableau $tab_day.
// valeurs possibles pour le 2e paramètre : celles du tableau $tab_adj
// a utiliser avec les jours de la semaine uniquement bien sur.

$tab = getdate(time());
$tab_month = array("janvier", "fevrier", "mars", "avril", "mai", "juin",
"juillet", "aout", "septembre", "octobre", "novembre", "decembre");

$numargs = func_num_args();
if ($numargs < 1)
return ("Pas assez d'arguments");
if ($numargs > 2)
return ("Trop d'arguments");
$tab_day = array("dimanche", "lundi", "mardi", "mercredi", "jeudi", "vendredi"
, "samedi", "avant-hier", "hier", "aujourd'hui", "demain", "apres-demain");
if (!(in_array($day, $tab_day)))
return 0;
$tab_fday = array_flip($tab_day);
$tab_adj = array("dernier", "prochain", "en 8", "en 15");
$tab_fadj = array_flip($tab_adj);
if ($numargs == 1)
{
if ($tab_fday[$day] < 7)
return 0;
$res = getdate($tab[0] + 86400 * ($tab_fday[$day] - 9));
$ind = $res["mon"] - 1;
return($res["mday"]." ".$tab_month[$ind]);
}
if ($numargs == 2)
{
if ($tab_fday[$day] > 7)
return 0;
$adj = func_get_arg(1);
if (!(in_array($adj, $tab_adj)))
return 0;
if ($tab_fday[$day] == $tab["wday"])
{
if ($tab_fadj[$adj] == 0)
$res = getdate($tab[0] - 86400 * 7);
else
$res = getdate($tab[0] + 86400 * 7 * $tab_fadj[$adj]);
}
else
$res = getdate($tab[0] + 86400 * ($tab_fday[$day] - $tab["wday"] + 7 * (
$tab_fadj[$adj] - 1)));
$ind = $res["mon"] - 1;
return($res["mday"]." ".$tab_month[$ind]);
}
return 0;
}
?>
<?php
/*------------------------------*/
/*
Titre : Retourne d'une date littérale la date exacte

Date édition : 15 Fev 2019
Date mise a jour : 30 Aout 2019

Rapport de la maj:
- fonctionnement du code vérifié
- correction du code
*/
/*------------------------------*/

function what_day_is($day){
// valeurs possibles pour $day : celles du tableau $tab_day.
// valeurs possibles pour le 2e paramètre : celles du tableau $tab_adj
// a utiliser avec les jours de la semaine uniquement bien sur.

$tab = getdate(time());
$tab_month = array("janvier", "fevrier", "mars", "avril", "mai", "juin",
"juillet", "aout", "septembre", "octobre", "novembre", "decembre");

$numargs = func_num_args();
if ($numargs < 1)
return ("Pas assez d'arguments");
if ($numargs > 2)
return ("Trop d'arguments");
$tab_day = array("dimanche", "lundi", "mardi", "mercredi", "jeudi", "vendredi"
, "samedi", "avant-hier", "hier", "aujourd'hui", "demain", "apres-demain");
if (!(in_array($day, $tab_day)))
return 0;
$tab_fday = array_flip($tab_day);
$tab_adj = array("dernier", "prochain", "en 8", "en 15");
$tab_fadj = array_flip($tab_adj);
if ($numargs == 1)
{
if ($tab_fday[$day] < 7)
return 0;
$res = getdate($tab[0] + 86400 * ($tab_fday[$day] - 9));
$ind = $res["mon"] - 1;
return($res["mday"]." ".$tab_month[$ind]);
}
if ($numargs == 2)
{
if ($tab_fday[$day] > 7)
return 0;
$adj = func_get_arg(1);
if (!(in_array($adj, $tab_adj)))
return 0;
if ($tab_fday[$day] == $tab["wday"])
{
if ($tab_fadj[$adj] == 0)
$res = getdate($tab[0] - 86400 * 7);
else
$res = getdate($tab[0] + 86400 * 7 * $tab_fadj[$adj]);
}
else
$res = getdate($tab[0] + 86400 * ($tab_fday[$day] - $tab["wday"] + 7 * (
$tab_fadj[$adj] - 1)));
$ind = $res["mon"] - 1;
return($res["mday"]." ".$tab_month[$ind]);
}
return 0;
}
?>

Exemple :

 
01
02
03
04
05
06
07
                    
<?php

echo what_day_is("demain");
echo what_day_is("hier");
echo what_day_is("lundi", "dernier");
echo what_day_is("lundi", "en 15");
?>
<?php

echo what_day_is("demain");
echo what_day_is("hier");
echo what_day_is("lundi", "dernier");
echo what_day_is("lundi", "en 15");
?>

      Fonctions du code - Doc officielle PHP

   php.net  
Description
Versions PHP
    array
Crée un tableau
PHP 4, 5, 7 et 8
    array_flip
Remplace les clés par les valeurs, et les valeurs par les clés
PHP 4, 5, 7 et 8
    echo
Affiche une chaîne de caractères
PHP 4, 5, 7 et 8
    func_get_arg
Retourne un élément de la liste des arguments
PHP 4, 5, 7 et 8
    func_num_args
Retourne le nombre d'arguments passés à la fonction
PHP 4, 5, 7 et 8
    getdate
Retourne la date/heure
PHP 4, 5, 7 et 8
    in_array
Indique si une valeur appartient à un tableau
PHP 4, 5, 7 et 8
    return
Retourne le controle du programme au module appelant
PHP 4, 5, 7 et 8
    time
Retourne l'horodatage UNIX actuel
PHP 4, 5, 7 et 8
Minimum 10 mots. Votre commentaire sera visible après validation.


 Autres snippets qui pourraient vous intéresser

En PHP obtenir date + heure MySQL au format FR

Compatibilité : PHP 5, PHP 7, PHP 8

Ce bout de code permet d'afficher une date de type DATETIME MySQL au format français en texte.

Date du jour en français avec PHP

Compatibilité : PHP 5, PHP 7, PHP 8

Fonction qui affiche la date du jour en français. Format: Jour de la semaine, le mois et l'année de manière littérale.

* Requêtes exécutées avec Recherche Contextuelle

  15 Fév 2019

Information sur les mises à jour

Dernière mise à jour :

30 Août 2019
fonctionnement du code vérifié
correction du code

1 910 Vues
Compatibilité du code
PHP 5, PHP 7, PHP 8
52 codes

Catégorie :  Dates - Heures

Addition de mois à une date
Affiche date et heure dynamiquement
Affiche la date dans une autre langue
Affiche la date de mise à jour d'1 page ou 1 script
Affiche la date du jour en Français
Affiche la date littérale en Français
Affiche le numéro de semaine ISO pour Windows
Affiche les dates du mois - Calendrier mensuel
Affiche les jours du mois
Affiche ligne par ligne les dates comprises entre 2 dates
Affiche une date avec le nom du jour et du mois
Ajoute ou soustrait des jours à une date
Calcul et affiche le lever et coucher du soleil
Calcul et trouve la date d'hier
Calcul l'age à partir d'une date de naissance avec PHP
Calcul l'age à partir de l'année
Calcul la date de Paque à partir d'une année
Calcul la différence de jour entre 2 dates
Calcul la différence entre 2 heures
Calcul la difference de temps du passé au présent
Calcul le nombre de jours écoulés depuis l'an zéro
Calcul le nombre de jours non-ouvrés entre 2 dates
Calcul le nombre de jours ouvrés entre 2 dates
Calcul le temps restant ou le temps écoulé
Calculer une date dans le futur
Change de format de date us <=> fr
Classement de dates dans 1 fichier
Compte à rebours du nouvel an
Compte le nombre de jour à partir d'une date
Convertie de secondes en heures, minutes et secondes
Convertie une date MySQL format US au format FR
Détermine rapidement si un jour est férié (fetes mobiles incluses)
Date du jour en français de manière littérale
Formulaire de date en HTML
Fractionne un créneau horaire entre l'heure de début et celle de fin
Gestion des semaines du lundi au lundi suivant
Indique si une année est bissextile ou pas
Injecte une Date SQL dans un tableau PHP
Lettres dominicales & Epacte julienne
Nombre de jours dans 1 mois
Obtient date + heure ( DATETIME ) au format littérale
Obtient la saison actuelle dans les 2 hémisphères
Quel sont les jours fériés en France
Retourne d'une date littérale la date exacte
Retourne le numéro de semaine passée en paramètre
Transforme une date dans un format littéraire et sympa
Trouve la date du prochain jour
Trouve les dates début et fin de semaine
Trouve si l'année est bissextile
Une autre utilisation de la fonction microtime ()
Vérifie la validité et l'existence d'une date
Vérifie si une date correspond au jour choisi