Dakle treba da kroz php pristupim jednom html file-u koji je izdjeljen u divove koje znam kako se zovu, i da izvadim sve sto se nalazi unutar jednog diva npr. :
<div id = content>
ovdje je neki tekst
ovdje je neki tekst
ovdje je neki tekst
...
</div>
E sad na php manual sam nasao nekih funkcija ali mi je sve to nekako konfuzno jer nisam nikad to radio. Cackao sam neki XML Reader ali bez uspjeha (nisam razumio primjere) Asistent iz datog predmeta mi je rekao za “XML parser” a kako radi to sam da rijesim. Moze li neka pomoc oko ovog. Bar odakle da krenem. Imam iskustva u php-u ako ce to pomoci.
Probacu ovo samo ne znam kako da uradim ne foreach nego tacno za jedan i samo jedan element. Posto ih moze biti istih naziva. Moze li preko id-a od div-a?
Nesto tipa foreach ($html->find(‘content’) as $element) onda ce naci samo jedan bez obzira sto je foreach jer nema istih id-ova. Mogao sam ovo isprobati dok sam otkucao ovaj post.
Probacu ovo samo ne znam kako da uradim ne foreach nego tacno za jedan i samo jedan element. Posto ih moze biti istih naziva. Moze li preko id-a od div-a?
Nesto tipa foreach ($html->find(‘content’) as $element) onda ce naci samo jedan bez obzira sto je foreach jer nema istih id-ova. Mogao sam ovo isprobati dok sam otkucao ovaj post. :D[/quote]
Sam si rekao
on trazi sve elemente, foreach radi upravo ono sto sam kaze, ako imas jedan element onda gi ne koristis.
On the other side, pogledaj kod klase, pa ce ti stvari biti malo jasnije
<?php
include ('simple_html_dom.php');
// Create DOM from URL or file
$html = file_get_html('index.html');
foreach($html->find('div[id=content]') as $element)
echo $element. '<br>';
?>
E da doslo je i do problema. U mom zadnjem postu sam napisao da navedena funkcija radi ok, ali je problem sledeci. Postoji dakle, index fajl sa jos par html dokumenata koji su medjusobno linkovani i sve to upakovano u neki css, dakle bez php-a. To je seminarski rad iz html-a jednog od studenata. Moj seminarski je da od svih studenata pokupim te seminarske i procitam parserom njihove linkove i to ubacim kod sebe u moj seminarski. e to sam napravio. ali mi je zadatak da postojece njiove linkove prepravim tako da kad se klikne na neki link, pozove se parser za taj link a ne sam taj link. E i to sad radi, ali vjerovali ili ne samo ako sadrzaj koji porsiram ne sadrzi navodnike (“dvostruke”). Tada se parser pogubi ili sta vec i isparsira sve linkove odjednom. Ukoliko sadrzaj nema navodnika sve radi kako treba. Danas sam sa asistentom vijecao 3h i skontali smo da je sigurno do navodnika. Sta da radim?
E ovako ovo neka je npr druga.html stranica koja sadrzi nesto ovako:
<div id = "content">
<p id="h3"> Položaj tačke u ravni </p>
<p id = "text">
Odredimo položaj tačke \(M\). Kroz tačku \(M\) možemo povući samo jednu pravu \(m\), koja je paralelan
sa ordinatnom osom, i jednu pravu \(n\), koja je paralelana sa apscisnom osom. Prava \(m\) presjeca apcisnu osu u
jednoj tački, neka je to tačka koja odgovara broju \(x=3\), a prava \(n\) presjeca ordinatnu osu u tački
koja odgovara broju \(y=2\). </p>
<div id = "image">
<center> <img src = "slike/2.jpg" width = "400" height = "300"/></center>
</div>
<p id="text">
Tački \(M\) dodijelimo par brojeva 3,2 , koji ćemo pisati u obliku \((3,2)\).
Ovaj par nazivamo uređen. Broj 3 nazivamo prva, a 2 druga koordinata uređenog para \((3,2)\). <br>
</br>
Dakle, na ovaj način možemo svakoj tački \(A\) ravni \(xOy\) pridružiti po jedan i samo jedan uređeni par
\((x,y)\) realnih brojeva. Vrijedi i obrnuto, svakom uređenom paru \((x,y)\) realnih brojeva možemo
pridružiti jednu i samo jednu tačku \(N\) ravni \(xOy\). <br>
Brojevi \(x\) i \(y\) nazivaju se koordinatama tačke \(A\). <br>
Tačku \(A\) koja je određena uređenim parom \((x,y)\), označićemo sa \(A(x,y)\).
</p>
<input type="button" value="Snimi stranicu" onclick="printpage()" />
</div>
moj zadatak je da napravim funkciju koja ce umjesto da otvori ovaj sadrzaj da isparsira ono sto ja hocu. u ovom slucaju je to sve unutar diva content. e ovo ne radi. zapravo radi ali isparsira mi sve linkove odjednom (ovo je jedan od njih). On i treba da isparsira sve linkove ali tek kad kliknem na njih. Kad kazem da ih isparsira, mislim da u drugom fajlu.php odakle pozivam parser, promijenim sadrzaj nekog drugog diva. npr div = “sredina”. E a ako ukinem sve sto sadrzi navodnike iz ovog gore koda onda sve radi ok
Dakle imam: fajl.php koji poziva parser za fajlove prva.html, druga.html…peta.html. U ovom mom php fajlu imam i nesto html koda, od kojeg je dio
ovo je neki kod u sredini
Treba da se ovaj gore div popunjava sadrzajem iz onih html fajlova kako ja kliknem na koji link. Nadam se da sam objasnio.