Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> rozbicie daty i zrobienie przedziału
chomiczek
post
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:
  1. 2010/02/24 2010/02/26

lub
  1. 2010/02/25 -> 2010/02/26 2010/02/22 2010/02/29


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
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi (1 - 4)
zegarek84
post
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 winksmiley.jpg

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ę.

Go to the top of the page
+Quote Post
chomiczek
post
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:
  1. while ($od = mysql_fetch_array($zap)) {
  2. var_dump($od['dataProm']);
  3. $x = explode(' ',$od['dataProm']);
  4. print_r($x);
  5. }


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
Go to the top of the page
+Quote Post
Fifi209
post
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...

  1. <?php
  2.  
  3. $string = '2010/02/24 2010/02/26';
  4.  
  5. var_dump($string);
  6.  
  7. $x = explode(' ', $string);
  8.  
  9. var_dump($x);
  10.  
  11. ?>


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
Go to the top of the page
+Quote Post
zegarek84
post
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 winksmiley.jpg - najlepiej, żebyś stronę miał kodowaną w unikode, potem luknij w źródło i sprawdź co siedzi między datami (może być znak jako znacznik html - nietypowo masz przechowywaną datę więc i to możliwe) / (ta "spacja" może być np. twardą spacją w unikode) itd. ...

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 winksmiley.jpg

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 winksmiley.jpg - mając znacznik html'a będziesz miał numer znaku i w tablicach odszukasz co to jest - ale do szczęścia Ci ta wiadomość nie jest potrzebna winksmiley.jpg

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ę.

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 Aktualny czas: 19.08.2025 - 20:18