Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> Preg_match wyrażenia regularne, Podczas pobierania strony curlem
sll
post
Post #1





Grupa: Zarejestrowani
Postów: 5
Pomógł: 1
Dołączył: 26.01.2010

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


Witajcie,

piszę ponieważ męczę się już 4h i nie daję rady. Otóż problem wygląda tak: pobieram za pomocą curla stronę i mam tam kilka elementów, które chciałbym wyświetlić. Przykładowa tabela z wynikami na jednej ze stron wygląda tak:
Kod
<div class=\"staty\">
    <h1>
        <table style=\"text-align: left; border-spacing: 10px 10px;\">
            <tr>
                <td><b>Tekst:</b></td><td><u>30,650</u></td>
            </tr>
            <tr>
                <td><b>Tekst</b></td><td><u>26,277.47</u></td>
            </tr>
            <tr>
                <td><b>Tekst:</b></td><td><u>23.1625</u></td>
            </tr>
            <tr>
                <td><b>Tekst:</b></td><td><u>5510</u></td>
            </tr>
            <tr>
                <td><b>Tekst:</b></td><td><u>0</u></td>
            </tr>
            <tr>
                <td><b>Tekst:</b></td><td><u>21</u></td>
            </tr>
            <tr>
                <td><b>Tekst:</b></td><td><u>52</u></td>
            </tr>
            <tr>
                <td><b>Tekst</b></td><td><u>0</u></td>
            </tr>
        </table>
    </h1>
</div>

Jak użyć funkcji preg_match_all, by najpierw znalazło mi tę konkretną tabelę (div class="staty"), a potem wszystkie ciągli liczb (ewentualnie zawartość tagów <u>). Oraz co dopisać, żeby zwróciło mi wszystkie te cyfry po kolei.

Wiem, że dla zorientowanego programisty to 30 sekund pisania kodu, dlatego mam nadzieję, że nie proszę o zbyt wiele, zwłaszcza, że chcę się nauczyć robić to sam (na innych stronach, z których chcę pobierać dane liczbowe będę musiał pisać nowe funkcje, ale chciałbym mieć jakiś szablonik). Pozdrawiam!
Go to the top of the page
+Quote Post
 
Start new topic
Odpowiedzi
sll
post
Post #2





Grupa: Zarejestrowani
Postów: 5
Pomógł: 1
Dołączył: 26.01.2010

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


Dzięki, naprowadziłeś mnie trochę i udało mi się osiągnąć efekt, jaki zamierzałem. Zamieszczam poniżej gdyby ktoś wyguglował ten temat.
Kod
$curl = curl_init();
curl_setopt ($curl, CURLOPT_URL, "http://imperiumreklamy.com/pages/index.php");
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$html = curl_exec ($curl);
curl_close ($curl);

// pobieram zawartość diva class="staty" z powyższej strony
preg_match("'<div class=\"staty\">(.*?)</div>'si", $html, $match);
    echo $match[1];

preg_match_all("/([0-9]+(\,[0-9]+)?)/", $match[1], $liczby);

//Wyrzuć całą zawartość tablicy
//print_r($liczby);

//wartości z przecinkami
//echo $liczby[1][3] . "<br />";
//echo $liczby[1][4] . "<br />";

//pozbądź się przecinków
$wynik = str_replace(",", " ", $liczby[1][3]);
$wynikk = str_replace(",", " ", $liczby[1][4]);

echo $wynik . "<br />";
echo $wynikk . "<br />";

Na końcu jeszcze usunąłem przecinki. Wolę wariant z liczbami niż z wycięciem zawartości <b> i <u> ponieważ na innych stronach, z których będę pobierał dane, bardzo możliwe, że nie będzie żadnych tagów.

Dziękuję jeszcze raz za pomoc (IMG:style_emoticons/default/smile.gif)
Go to the top of the page
+Quote Post

Posty w temacie


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

 



RSS Aktualny czas: 28.12.2025 - 12:51