Avatar billede hoppe11 Nybegynder
30. august 2009 - 11:24 Der er 1 kommentar og
1 løsning

fread() læse bestemt antal linjer

hej

hvordan kan jeg med fread()/fgets() trække et bestemt antal linjer ud af min fil? f.eks. 0-99, 100-199 osv

jeg kan ikke bruge file() eller lign. da det overskrider min memory limit
Avatar billede coderdk Praktikant
30. august 2009 - 11:36 #1
Jeg har ikke prøvet, men du burde kunne bruge fgetcsv og bare angive en eller anden usansylig separator (f.eks. "|")

http://dk2.php.net/fgetcsv
Avatar billede hoppe11 Nybegynder
30. august 2009 - 11:59 #2
jeg fandt selv en løsning :)

ellers tag for hjælpen :)

    $fp = fopen($_GET['file'], 'r');
   
    $query = sprintf(fgets($fp), $DB, $table[1]);
   
    while(!feof($fp))
    {
        $i = 0;
        $insert_arr = array();
        while(!feof($fp))
        {
            if($line = fgets($fp)) $insert_arr[] = $line;
           
            if($i > 1000) break;
           
            $i++;
        }
       
        if($insert_arr)
        {
            mysql_query($query.' '.implode(',', $insert_arr))or die(mysql_error()),;
        }
    }
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Vi tilbyder markedets bedste kurser inden for webudvikling

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester