Bonjour à tous,

J'ai développé une fonction qui permet de récupérer les X derniers mois suivant le paramètre qu'on passe à la fonction.
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
 
function getLatestMonth($dernierMois){
        $oDateDuJour = new DateTime();
        $arParMois = array();
 
        for($i = 0; $i < $dernierMois; $i++){
            if($i === 0){
                $arParMois[$i] = array(
                    'firstDay' => '01',
                    'lastDay' => $oDateDuJour->format('d'),
                    'month' => $oDateDuJour->format('m'),
                    'year' => $oDateDuJour->format('Y')
                );
            }else{
                //On enlève 1 mois à la date du jour
                $oDateDuJour->modify('-1 months');
                $arParMois[$i] = array(
                    'firstDay' => '01',
                    //t renvoie le nombre de jour dans un mois, donc le dernier jour du moi !
                    'lastDay' => $oDateDuJour->format('t'),
                    'month' => $oDateDuJour->format('m'),
                    'year' => $oDateDuJour->format('Y')
                );
            }
        }
 
        return $arParMois;
    }
Donc si je fais getLatestMonth(5), va me retourner un tableau avec les 5 derniers mois. On aura un résultat du type :
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
 
Array
(
    [0] => Array
        (
            [firstDay] => 01
            [lastDay] => 06
            [month] => 08
            [year] => 2012
        )
 
    [1] => Array
        (
            [firstDay] => 01
            [lastDay] => 31
            [month] => 07
            [year] => 2012
        )
 
    [2] => Array
        (
            [firstDay] => 01
            [lastDay] => 30
            [month] => 06
            [year] => 2012
        )
 
    [3] => Array
        (
            [firstDay] => 01
            [lastDay] => 31
            [month] => 05
            [year] => 2012
        )
 
    [4] => Array
        (
            [firstDay] => 01
            [lastDay] => 30
            [month] => 04
            [year] => 2012
        )
 
    [5] => Array
        (
            [firstDay] => 01
            [lastDay] => 31
            [month] => 03
            [year] => 2012
        )
 
)
On remarque le tableau à l'indice 0 où le lastDay est le 6 (normal c'est la date du jour). Le problème vient quand on se trouve en fin de mois. Si on était le 31.07.2012 :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
 
$ladate = new DateTime("31.07.2012");
$ladate->modify('-1 months');
echo $ladate->format("d.m.Y");//Affiche 01.07.2012
Le résultat est logique puisque juin compte 30 jours.

Est-ce que quelqu'un aurait une idée pour corriger ce petit désagrément ?

Merci à tous pour votre aide.