Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: wyciąganie i definiowanie zmiennych z kilkoma separatorami
Forum PHP.pl > Forum > PHP
kowalcook
witam,
mam taki mały problem, mianowicie mam taki oto adres http://www.krankenkassensuche.de/rechner/f...n.php?land_id=1

są tu wygenerowane z bazy dane ktore musze przetworzyć i zastosowac na innym site (adres powyżej jest afiliatem i nie mam dostępu do pliku źródłowgo)

jak wydać na pliku są 2 separatory ; który oddziela poszczególne dane(komórki) oraz spacja która oddziela poszczególne wpisy (rekordy) co gorsza spacja wystepuje też w nazwach co trochę komplikuje sprawe, musiałaby poprostu rozdzielać rekordy co 2 średniki i spacja

moje pytanie jest następujące
w jaki sposób mógłym wyciągnąc te dane z tej strony i przetworzyć je w php w pętli jako pojedyńcze wpisy

obrazując wyszło by coś takiego:
  1. <?php
  2. $dane1[0]; $dane2[0]; $dane3[0]
  3. $dane1[1]; $dane2[1]; $dane3[1]
  4. $dane1[2]; $dane2[2]; $dane3[2]
  5. itd
  6. ?>


dodatkowym utrudnieniem jest fakt iż ilość rekordów jest zmienna
http://www.krankenkassensuche.de/rechner/f...n.php?land_id=1 -> tu jest inna
http://www.krankenkassensuche.de/rechner/f...n.php?land_id=2 -> i tu jest inna itd


proszę o pomoc w jaki sposób mógłbym to zrobić
z góry wielkie dzięki
kowalcook
nospor
Cytat
oraz spacja która oddziela poszczególne wpisy (rekordy)
Jakbys zajrzal w zrodlo, to bys wiedzial ze to nie spacja a znak konca linii. To duza roznica.
Jest to zwykly csv i jest na niego wiele metod. Albo korzystasz z gotowych klas (mnostwo w sieci)
albo piszesz sam (pseudokod):
1)rozbijasz to najpierw po znakach konca wiersza (explode)
2)lecisz w petli po otrzymanej tablicy
3) dla kazdego elementu robisz explode po sredniku i dobierasz sie w ten sposob do kolumn w danym wierszu
My4tic
Spacja to raczej tu nie może być separatorem bo masz ją w nazwach własnych. Co do reszty to http://pl2.php.net/manual/pl/function.explode.php

// edit

Widze, ze ktos mnie wyprzedził :-)
kszychu
A najlepiej na początku załadowąc to wszystko za pomocą file(). Wtedy mamy już każdą linijkę w osobnej komórce tablicy.
kowalcook
dzięki @nospor smile.gif

rzeczywiście nie zajżałem w źródło pliku

nie ma to jak być spostrzegawczym smile.gif


dla zainteresowanych podaje kod jak to można zrobić

  1. <?php
  2. $location = "adres ścieżki z danymi";
  3. $html = @file_get_contents($location);
  4. $wyciag = explode("n", $html);  // gdzie "n" jest separatorem 1
  5. $ile = count($wyciag);
  6. $i = 1;
  7. while($i < $ile){
  8. $dane = explode(";", $wyciag[$i]);
  9.  
  10. echo "$dane[0] $dane[1] $dane[2]"; // przetwarzamy to jak uważamy za stosowne
  11. echo "<br>";
  12.  
  13. $i++;
  14. }
  15. ?>



jeszcze raz dzięki i pozdrawiam
kowacook
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.