Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [php/mysql] funkcja dzisiaj, wczoraj
M@X
post 1.09.2010, 18:07:12
Post #1





Grupa: Zarejestrowani
Postów: 212
Pomógł: 0
Dołączył: 18.12.2003
Skąd: Warszawa

Ostrzeżenie: (0%)
-----


Witam.
Mam taką funkcje która pobiera z bazy date w formacie DATETIME 0000-00-00 00:00:00
Funkcja porównuje date dzisiejszą do tej z bazy więc jeśli w bazie jest np: 2010-09-01 to wyświetla napis: "dzisiaj", natomiast jeśli w bazie jest 2010-08-31 to wyświetla napis "wczoraj", w każdym innym wypadku powinna wyświetlać po prostu date z bazy.
Wszystko fajnie działało jednak w momencie jak sie pojawił nowy miesiąc, to nagle wszystkie daty starsze niż wczoraj, pokazują napis wczoraj. Jak to można rozwiązać ?

  1. <?
  2. function kiedydata($czas) {
  3.  
  4. $tab = explode(" ",$czas);
  5. $dzisiaj = date('Y-m-d');
  6. $wczoraj = explode("-",$tab[0]);
  7. $p_wczoraj = explode("-",$dzisiaj);
  8. if (($p_wczoraj[2] - $wczoraj[2]) == 1 || ($p_wczoraj[2] - $wczoraj[2]) < 0)
  9. $tab[0] = "Wczoraj";
  10. if ($tab[0] == $dzisiaj)
  11. $tab[0] = "Dzisiaj";
  12.  
  13. return $tab[0]." <small>".$tab[1]."</small>";
  14. }
  15. ?>


--------------------
"timeo danaos at dona ferentes"
Go to the top of the page
+Quote Post
AlexDeLarge
post 1.09.2010, 18:56:58
Post #2





Grupa: Zarejestrowani
Postów: 85
Pomógł: 14
Dołączył: 14.02.2010

Ostrzeżenie: (0%)
-----


Podpowiem, że "wczoraj" zaczyna się na:

  1. mktime(0, 0, 0, date('m'), date('d')-1, date('Y'));


a kończy:
  1. mktime(23, 59, 59, date('m'), date('d')-1, date('Y'));



--------------------
Java and PHP developer 2007-2014 :)
Go to the top of the page
+Quote Post
michaJlS
post 1.09.2010, 19:50:46
Post #3





Grupa: Zarejestrowani
Postów: 83
Pomógł: 9
Dołączył: 21.05.2004
Skąd: Glogau/Breslau

Ostrzeżenie: (0%)
-----


Jest jeszcze jedna taka zajebiaszcza fjca w php jak http://php.net/manual/en/function.strtotime.php - popatrz po przykładach, to Ci może życie ułatwi.
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
1 Użytkowników czyta ten temat (1 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Wersja Lo-Fi Aktualny czas: 14.08.2025 - 05:08