![]() |
Hämta filer med php script (lite hjälp)
Hej
Söker ett skript som hämtar filer info enligt en fil-lista. Har ett script färdigt men det hämtar bara en sida och inte alla från listan. <?php $url = "XXXXXX347415"; $content = file_get_contents($url); $titlestart=strpos($content,"<table>"); $titleslut = strpos($content,"</table>"); $spec=substr($content,$titlestart,$titleslut-$titlestart)."</table>"; file_put_contents("347415.htm",$spec,LOCK_EX); ?> <?php echo $spec; ?> |
Det ser ut som att du försöker tolka HTML med något som liknar reguljära uttryck. Jag rekommenderar att du använder PHPs in inbyggda XML-klasser för att tolka dokument istället, så kan du till exempel plocka ut alla noder av en viss typ och iterera över dem, alltså oavsett hur många noder det är.
Ett enkelt exempel där jag skriver ut innehållet i alla <p>-element: Kod:
$html = new DOMDocument(); |
Citat:
Ditt script fungerar nog också men det hjälper inte mig. Det hämtar ändå bara från 1st angiven sida och inte enligt fillistan.txt med ca 1000 länkar. |
Mitt skript visar en metod att tolka HTML-filer. Du har ännu inte sagt vad du ska med det till, eller ens vad som blir fel.
|
Citat:
Scriptet ska läsa först länken i fillista.txt och med hjälp av reguljära uttryck hämta tex en tabel som finns på den sidan länk 1 hänvisar till i fillista.txt När den är hämtad ska den spars ner till en fil med det fil namn som finns i länk nr 1 i fillistan Där efter börjar det om igen med länk nr 2 och så vidare. Scriptet jag har fungerar men doch bara på 1st angiven länk sida. |
Citat:
Men däremot är de att rekommendera. |
Citat:
Kod:
$list = file_get_contents("listan.txt"); |
Citat:
Testade det och fick felmedelande. Warning: file_get_contents() [function.file-get-contents]: Filename cannot be empty in C:\wamp\www\script\test.php on line 5 |
Troligtvis innehåller din list-fil även en radbrytning på slutet av sista raden. Det gör att loopen kör en sista gång på en tom rad. Lägg in en if-sats i början av loopen och kolla om raden är tom.
|
Citat:
Koden fungerar bra så långt. Men den hämtar dock bara info från sista länken "raden" i list-filen. <?php $list = file_get_contents("listan.txt"); $urls = explode("\n",$list); foreach($urls as $url) { $file = file_get_contents($url); $tablestart=strpos($file,"<table>"); $tableslut = strpos($file,"</table>"); $spec=substr($file,$tablestart,$tableslut-$tablestart)."</table>"; /* Insert other blablabla-code here */ } ?> <?php echo $spec; ?> |
PHP-kod:
|
Citat:
Då är frågan bara hur man ska koda för att få varje rad sparad som en fil. |
Citat:
|
Citat:
file_put_contents Men måste väll ha någon counter eller någon så att alla filer sparas med olika filnamn. |
Citat:
|
Citat:
Ännu bättre vore om man kunde få ut siffrorna från länken i fil-listan Länkarna ser ut så här: xxx = dold katalog http://xxx/xxx/ki.aspx?sku=334512&view=detailed http://xxx/xxx/ki.aspx?sku=334425&view=detailed http://xxx/xxx/ki.aspx?sku=334514&view=detailed http://xxx/xxx/ki.aspx?sku=344466&view=detailed Här skulle man försöka få ut namnet i första loppen 334512 och som då blir namnet på "filnr1" 334512.htm och nästa fil kommer då få namnet 334525.htm |
Citat:
Vet Komplett om att du snor deras produkttexter? För ni som tvivlar: http://www.komplett.se/k/ki.aspx?sku=434502 http://www.komplett.se/k/ki.aspx?sku...&view=detailed Matchar ganska exakt in på länkarna du angivit |
Om numret alltid är på samma position och har samma längd:
PHP-kod:
Du måste förstås ha tillstånd om det är så att du har tänkt kopiera information från någon annans sida och publicera den själv. |
Citat:
Ett lite problem bara ÅÄÖ blir fel i den sparade html filen. Har testat och spara i txt samt i php filer och då blir det rätt. Blir även rätt vid visning php echo |
Alla tider är GMT +2. Klockan är nu 03:24. |
Programvara från: vBulletin® Version 3.8.2
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Svensk översättning av: Anders Pettersson