PHPerKaigi 2025

gregoriantojd

(PHP 4, PHP 5, PHP 7, PHP 8)

gregoriantojdConvertit une date grégorienne en nombre de jours du calendrier Julien

Description

gregoriantojd(int $month, int $day, int $year): int

L'intervalle de validité pour le calendrier grégorien est du 25 novembre, 4714 avant J.C. à au moins le 31 décembre 9999 après J.C.

Bien qu'il soit possible de manipuler des dates jusqu'en 4714 avant JC, une telle utilisation n'est pas significative. En effet, ce calendrier fut créé le 18 octobre 1582 après J.C. (ou 5 octobre 1582 en calendrier grec). Certains pays ne l'acceptèrent que bien plus tard. Par exemple, les britanniques n'y passèrent qu'en 1752, les Russes en 1918 et les Grecs en 1923. La plupart des pays européens utilisaient le calendrier Julien avant le Grégorien.

Liste de paramètres

month

Le mois, sous la forme d'un nombre compris entre 1 (pour Janvier) et 12 (pour Décembre)

day

Le jour, sous la forme d'un nombre compris entre 1 et 31. Si le mois a moins de jours que fournit, un débordement se produit ; voir exemple ci-dessous.

year

L'année, sous la forme d'un nombre compris entre -4714 et 9999. Les nombres négatifs signifie les années avant J.C., les nombres positifs signifie après J.C. Il est à noter qu'il n'y a pas d'année 0 ; 31 décembre, 1 avant J.C is immédiatement suivit par 1 janvier, 1 après J.C.

Valeurs de retour

Le jour Julien pour la date Grégorienne fournie, sous la forme d'entier. Les dates en dehors de l'intervalle valide retourne 0.

Exemples

Exemple #1 Fonctions calendrier

<?php
$jd
= gregoriantojd(10, 11, 1970);
echo
"$jd\n";
$gregorian = jdtogregorian($jd);
echo
"$gregorian\n";
?>

L'exemple ci-dessus va afficher :

2440871
10/11/1970

Exemple #2 Comportement de débordement

<?php
echo gregoriantojd(2, 31, 2018), PHP_EOL,
gregoriantojd(3, 3, 2018), PHP_EOL;
?>

L'exemple ci-dessus va afficher :

2458181
2458181

Voir aussi

  • jdtogregorian() - Convertit le nombre de jours du calendrier Julien en date grégorienne
  • cal_to_jd() - Convertit un calendrier en nombre de jours Julien

add a note

User Contributed Notes 3 notes

up
1
jettyrat at jettyfishing dot com
19 years ago
You can obtain the decimal fraction of the Julian date with the php gregoriantojd() function or the function shown below by applying this code to the returned value.

<?php
$julianDate
= gregoriantojd($month, $day, $year);

//correct for half-day offset
$dayfrac = date('G') / 24 - .5;
if (
$dayfrac < 0) $dayfrac += 1;

//now set the fraction of a day
$frac = $dayfrac + (date('i') + date('s') / 60) / 60 / 24;

$julianDate = $julianDate + $frac;
?>
up
1
httpwebwitch
20 years ago
This function also ignores decimal fractions in JD dates, and it uses non-standard format for returning the Gregorian date.

So, if your JD date is 2453056.28673, the Gregorian returned value is 2/20/2004, not "2004-02-20 23:45:36"

The decimal part is important, since the Julian day begins at noon, for example 2453056.49 is on Friday, 2453056.50 is on Saturday. Discarding the decimal part means that your returned Gregorian Date will be wrong 50% of the time.
up
-1
jfg
15 years ago
If you need the same output as the g_date_get_julian function of the GlibC, here is my php implementation :

<?php
/**
* Glib g_date_get_julian PHP implementation
*
* @param $str Date string in a format accepted by strtotime
* @author jfg
*/
private function _get_julian( $str )
{
$d = date_create($str);

if(
$d == false )
return
0;

$day_in_year = (int) date_format($d, "z");
$year = (int) date_format($d, "Y") - 1;
$julian_days = $year * 365;
$julian_days += ($year >>= 2);
$julian_days -= ($year /= 25);
$julian_days += $year >> 2;
$julian_days += $day_in_year + 1;

return
ceil($julian_days);
}

?>
To Top