![]() |
![]() |
![]()
Post
#1
|
|
![]() Grupa: Zarejestrowani Postów: 271 Pomógł: 4 Dołączył: 5.01.2005 Ostrzeżenie: (0%) ![]() ![]() |
Mam taki problem, a mianowicie w bazie danych mam daty i/lub zakresy dat w formie:
lub
pogrubiony element oznacza zakres od do. W jaki sposób wyliczyć poszczególne elementy z przedziału? zamieniać date od i datę do na znacznik czasu i potem robić +24*60*60 i sprawdzać czy wynik jest równy do, jeśli nie kolejny raz powtarzać pętle? Ogólnie potrzebuję daty w postaci: 2010/02/29, ale to nie problem jak ją będę wyświetlał, kwestia jak te przedziały pozamieniać na pojedyncze daty, mając oczywiście na uwadze wydajność i czas?? -------------------- created by chomiczek
|
|
|
![]() |
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 1 332 Pomógł: 294 Dołączył: 12.10.2008 Skąd: Olkusz Ostrzeżenie: (0%) ![]() ![]() |
niezbyt jasno opisałeś problem - np. jak dokładnie te dane są przechowywane, czy to jeden string czy s w osobnych kolumnach?? (piszesz, że coś jest pogrubione - gdzie?)
jeśli masz php 5.3 to znacznie ułatwi Ci pracę klasa DateTime class i przy użyciu metody DateTime::createFromFormat możesz tworzyć obiekt z dowolnego typu znacznika czasu... (są tam tez metody porównywania różnicy między datami itd...) jeśli nie to musisz korzystać z funkcji daty i czasu a w szczególności raczej by się przydały takie funkcje jak: strptime() Parse a time/date generated with strftime mktime() Oblicza uniksowy znacznik czasu dla podanej daty i najlepiej to liczyć w uniksowym znaczniku czasu oraz funkcje typu: sscanf() - Parses input from a string according to a format explode... itd. - manual Twoim przyjacielem ![]() Ten post edytował zegarek84 23.02.2010, 14:26:09 -------------------- Jeśli twoja ręka rusza do przodu powstrzymaj swój gniew; gdy wyprzedza cię twój gniew - wycofaj rękę.
|
|
|
![]()
Post
#3
|
|
![]() Grupa: Zarejestrowani Postów: 271 Pomógł: 4 Dołączył: 5.01.2005 Ostrzeżenie: (0%) ![]() ![]() |
Co do pogrubienia to faktycznie, teraz widzę, że tego nie widać.. chodzi o ->, który określa przedział od do..
Daty w bazie są jako string.. niby ok, ale poniższy fragment kodu nie daje oczekiwanego wyniku:
spowoduje mi zwrócenie: string(21) "2010/02/24 2010/02/26" Array ( [0] => 2010/02/24 2010/02/26 ) czyli string nie jest rozbijany?? dlaczego?? -------------------- created by chomiczek
|
|
|
![]()
Post
#4
|
|
![]() Grupa: Zarejestrowani Postów: 4 655 Pomógł: 556 Dołączył: 17.03.2009 Skąd: Katowice Ostrzeżenie: (0%) ![]() ![]() |
Dziwne, u mnie działa...
Kod string(21) "2010/02/24 2010/02/26" array(2) { [0]=> string(10) "2010/02/24" [1]=> string(10) "2010/02/26" }
-------------------- Zainteresowania: C#, PHP, JS, SQL, AJAX, XML, C dla AVR
Chętnie pomogę, lecz zanim napiszesz: Wujek Google , Manual PHP |
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 1 332 Pomógł: 294 Dołączył: 12.10.2008 Skąd: Olkusz Ostrzeżenie: (0%) ![]() ![]() |
zapewne to jest inny znak niż spacja
![]() jeśli masz kodowanie w unikode to powinno wystarczyć jak znak między datami skopiujesz i w skrypcie też zapisane pliki jako utf-8 wkleisz tą "spacje" w pojedyńczy apostrof.... (przypominam - skopiuj ze źródeł wyświetlonej strony) na ogół to pomaga unikode bardzoooo ułatwia życie ![]() a jeśli bardzoooo chcesz wiedzieć jaki to dokłądnie znak choć do szczęścia Ci to nie potrzebne to możesz się do tego dobrać używając funkcji mb_encode_numericentity - popatrz na przykład użycia i na komentarze - niżej w komentarzu masz napisaną specjalnie funkcje utf2html - nazwa mówi sama przez się jakie znaki zostaną pozmieniane ![]() ![]() Ten post edytował zegarek84 23.02.2010, 14:54:44 -------------------- Jeśli twoja ręka rusza do przodu powstrzymaj swój gniew; gdy wyprzedza cię twój gniew - wycofaj rękę.
|
|
|
![]() ![]() |
![]() |
Aktualny czas: 19.08.2025 - 20:18 |