如何在PHP中拆分不同的日期格式?

时间:2015-05-26 07:43:31

标签: php mysql date

我有一些这样的日期:

  • 15Décembre2012
  • Du mardi 18 avril au jeudi 25 mai
  • Le 25,26 et 27 Juin

只是法语的例子。

我的数据库看起来像:

 CREATE TABLE DateTest(id_date int(11), date text, date_deb date, date_fin date);

我想插入不同的日期,无论它们的格式如何。 我可以很容易地插入第一个例子,第二个例子,但是关于第一个例子,我不知道..

它可以有很少的分隔符(或等),当我得到当天的数字(第一个为25)时,我没有月份。

1 个答案:

答案 0 :(得分:0)

我会做的是写几个正则表达式来捕捉可以输入这些日期的不同方式。对于第三种格式,例如:

$month_nrs = array('janvier' => 1, 'février' => 2, 'mars' => 3, 'avril' => 4, 'mai' => 5, 'juin' => 6, 'juillet' => 7, 'août' => 8, 'septembre' => 9, 'octobre' => 10, 'novembre' => 11, 'décembre' => 12);

$period = 'Le 25, 26 et 27 Juin';
//$period = 'Le 25 et 26 Juin';
//$period = 'Le 25, 26, 27 et 28 Juin';
if (preg_match('/(\d{1,2})(?:,\s*\d{1,2})* et (\d{1,2})\s+(janvier|février|mars|avril|mai|juin|juillet|août|septembre|octobre|novembre|décembre)/i', $period, $matches)) {
    $month_name = strtolower($matches[3]);
    $month_nr = $month_nrs[$month_name];
    $day_deb = $matches[1];
    $day_fin = $matches[2];
    $date_deb = date('Y').'-'.$month_nr.'-'.$day_deb;
    $date_fin = date('Y').'-'.$month_nr.'-'.$day_fin;

    echo "Date deb: $date_deb, date fin: $date_fin";
}