![]() |
![]() ![]() |
![]() |
![]()
Post
#1
|
|
Grupa: Zarejestrowani Postów: 259 Pomógł: 0 Dołączył: 12.07.2009 Ostrzeżenie: (10%) ![]() ![]() |
Nie jestem pewna, czy to dobry dział, ale chyba tak:) Mam w bazie danych w jednym polu kilka tabel. To znaczy, kolejne wiersze tabeli są oddzielone znakiem końca linii, a pusta linia (zawiera tyko znak końca linii) oddziela dwie tabele. I mam bardzo duży kłopot z ich poprawnym wyświetleniem. Chciałabym, żeby pierwszy wiersz każdej tabeli był wierszem nagłówkowym. A do tego, żeby wszystkie wiersze miały na przemian zdefiniowane klasy (parzyste będą zielone, a nieparzyste różowe). Jeśli mam jedną tabele, to potrafię wszystko zrobić., ale jeśli jest ich kilka, to już nie (IMG:http://forum.php.pl/style_emoticons/default/sad.gif)
Próbowałam najpierw odczytać takie dane z pliku, żeby wyeliminować problemy z bazą, ale też nie umiem. Jedyne co wymyśliłam, to dwukrotne analizowanie tekstu:1 - rozdzielam tabele, 2 - wstawiam wiersz nagłówkowy i koloruję wiersze. Ale to bardzo zagmatwane jest. Błagam pomóżcie mi to rozwiązać. |
|
|
![]()
Post
#2
|
|
Grupa: Zarejestrowani Postów: 16 Pomógł: 4 Dołączył: 18.02.2007 Ostrzeżenie: (0%) ![]() ![]() |
Podaj więcej informacji. Jaka baza MySQL? Pokaż strukturę i przykładowe dane.
|
|
|
![]()
Post
#3
|
|
Grupa: Zarejestrowani Postów: 259 Pomógł: 0 Dołączył: 12.07.2009 Ostrzeżenie: (10%) ![]() ![]() |
Struktura jest taka:
---------początek pliku/pola w bazie ------ a11;; a21;a22;a23 a31;a32;a33 a41;a42;a43 b11;; b21;b22;b23 b31;b32;b33 ------koniec pliku/pola w bazie--------------- i teraz coś takiego chcę wyświetlić. Jak widzisz jest ot kilka tabel i chciałabym aby każda tabela miała w pierwszym wierszu komórki nagłówkowe <th> i w dodatku aby wszystkie wiersze miały na przemian dodane klasy do do <tr>. Największa trudność to rozpoznanie osobnych tabel w całym polu, bez 2 przebiegów po pliku. A baza do Sqlite. |
|
|
![]()
Post
#4
|
|
Grupa: Zarejestrowani Postów: 4 655 Pomógł: 556 Dołączył: 17.03.2009 Skąd: Katowice Ostrzeżenie: (0%) ![]() ![]() |
Chodziło mu bardziej o coś takiego:
`nazwatabeli` Pola: `id` int not null auto_increment `naglowek` varchar(255) etc. Bo to co Ty napisałaś jako strukturę....jest...dziwne (IMG:http://forum.php.pl/style_emoticons/default/haha.gif) W dodatku opis problemu jest zagmatwany, napisz dokładnie po kolei co chcesz otrzymać a potem mniej więcej jak próbowałaś to zrobić. |
|
|
![]()
Post
#5
|
|
Grupa: Zarejestrowani Postów: 259 Pomógł: 0 Dołączył: 12.07.2009 Ostrzeżenie: (10%) ![]() ![]() |
w bazie mam jedną tabelę, a w niej:
numerID | tekst | tabele i to co napisałam wcześniej to jest w polu tabele. I tam w tym polu jest jedna albo dwie albo trzy tabele, każda oddzielona pustym wierszem, a zapis kolumn i wierszy w tych najmniejszych tabela jest tak jak w CSV. Bo ja przekleiłam z excela do bazy te tabele. Ale nie potrafię ich wyświetlić jako kilku tabel z na przemian kolorowanymi wierszami i wierszem nagłówkowym. Dałabym rade to zrobić ale musiałabym całe pole analizowac dwukrotnie, raz szukać tabel, a raz po to by nadac im atrybuty class. Prosze pomóżcie. |
|
|
![]()
Post
#6
|
|
Grupa: Zarejestrowani Postów: 16 Pomógł: 2 Dołączył: 30.05.2009 Ostrzeżenie: (0%) ![]() ![]() |
Temat do przeniesienia.
1. W PHPie robisz to tak:
Ok, pisane z palca, może nie działać, ale logika oddana. Kolorowanie wierszy bez problemu - sprawdzasz czy $i jest parzyste, jeśli tak dajesz klasę z jednym kolorem, jeżeli nie z drugim. |
|
|
![]()
Post
#7
|
|
Grupa: Zarejestrowani Postów: 259 Pomógł: 0 Dołączył: 12.07.2009 Ostrzeżenie: (10%) ![]() ![]() |
Dzięki, chyba już zrozumiałam (IMG:http://forum.php.pl/style_emoticons/default/smile.gif)
Wyjaśnij mi tylko ten fragment: $tabele = explode("\n\n\n",$dane); czy nie powinnam wpisać "\r\n\r\n" zamiast "\n\n\n"? Jedna para \r\n na zakończenie poprzedniej tabelki i jedna na wiersz przerwy, który jest pusty. Popraw mnie jeśli jednak źle myślałam? I jeszcze jedna ważna sprawa! W polach tabeli CSv czasami są średniki, wtedy są też " czyli zwykłe explode( ';' nie jest dobre. Jak to poprawić? |
|
|
![]()
Post
#8
|
|
Grupa: Moderatorzy Postów: 15 467 Pomógł: 1451 Dołączył: 25.04.2005 Skąd: Szczebrzeszyn/Rzeszów ![]() |
Poszukaj gotowej klasy do przetwarzania CSV, będzie z głowy problem ze średnikami.
Cytat czy nie powinnam wpisać "\r\n\r\n" zamiast "\n\n\n"? Jedna para \r\n na zakończenie poprzedniej tabelki i jedna na wiersz przerwy, który jest pusty. Popraw mnie jeśli jednak źle myślałam? http://forum.php.pl/index.php?showtopic=84239 |
|
|
![]()
Post
#9
|
|
Grupa: Zarejestrowani Postów: 259 Pomógł: 0 Dołączył: 12.07.2009 Ostrzeżenie: (10%) ![]() ![]() |
Już sobie poradziłam (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) A ze średnikami nie będzie problemu bo niedługo na tą wersje 5,3 się planuję przerzucić. A czy powiedziałbym mi ktoś, bo ja nie bardzo się w tym potrafiłam zorientować czy ona jest już stabilna? Wydaje mi się, że nie ale może się pomyliłam.
|
|
|
![]()
Post
#10
|
|
Grupa: Moderatorzy Postów: 15 467 Pomógł: 1451 Dołączył: 25.04.2005 Skąd: Szczebrzeszyn/Rzeszów ![]() |
Spokojnie, zanim wszędzie będzie PHP 5.3, to jeszcze sporo wody w Wiśle upłynie. (IMG:http://forum.php.pl/style_emoticons/default/tongue.gif)
Osobiście bojkotuję 5.3 czekając na 5.3.1 (IMG:http://forum.php.pl/style_emoticons/default/aaevil.gif) |
|
|
![]()
Post
#11
|
|
Grupa: Zarejestrowani Postów: 16 Pomógł: 2 Dołączył: 30.05.2009 Ostrzeżenie: (0%) ![]() ![]() |
Dzięki, chyba już zrozumiałam (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Wyjaśnij mi tylko ten fragment: $tabele = explode("\n\n\n",$dane); czy nie powinnam wpisać "\r\n\r\n" zamiast "\n\n\n"? Jedna para \r\n na zakończenie poprzedniej tabelki i jedna na wiersz przerwy, który jest pusty. Popraw mnie jeśli jednak źle myślałam? I jeszcze jedna ważna sprawa! W polach tabeli CSv czasami są średniki, wtedy są też " czyli zwykłe explode( ';' nie jest dobre. Jak to poprawić? Najłatwiej będzie, jeżeli sprawdzisz czy działa na Twoich plikach (IMG:http://forum.php.pl/style_emoticons/default/smile.gif) Nie wiem, jak są zapisywane (czy ręcznie pod Windowsem, czy pod Linuxem, czy z jakiegoś programu generowane...). Nie podałem Ci idealnego rozwiązania - pokazałem przykładowe podejście do tematu. Oczywiście - najłatwiej dla czegoś ustandaryzowanego (jeśli jest to w pełni format CSV, chyba rzeczywiście najłatwiej przejrzeć dostępne klasy). Jeżeli jednak Twój format nie jest standaryzowany lub możliwe są różne wariacje - musisz sprawdzać więcej warunków. Możesz np. korzystać z strpos() i wyszukiwać jaki jest format danych i w zależności od niego wykonywać dalsze operacje. Najnowszą stabilną wersję znajdziesz zawsze pod adresem: http://www.php.net/downloads.php (IMG:http://forum.php.pl/style_emoticons/default/winksmiley.jpg) Chyba najłatwiejsza forma weryfikacji ;-) |
|
|
![]() ![]() |
![]() |
Aktualny czas: 4.10.2025 - 00:18 |