1

我有一个这样排列的文件:
"url1","info1"
"url2","info2"
"url3","info3" ... 一直到 "url15","info15"

我想将文件的最后 10 行读入一个数组,这样 $pagelist[0][0] 会给出 url5,$pagelist[0][1] 会给出 info5。

我目前的代码如下:

$file=fopen(csvfile.txt,"r");
$pagelist=array();
$i=0;
$key=0;
while (!feof($file)) {
    if ($i >= (count($file)-11)) {
        $pagelist[$key]=fgetcsv($file);
        $key++; }
    $i++;
}
fclose($file)

当我使用 print_r($pagelist) 时,它似乎已将文件的所有行加载到数组中,而不仅仅是最后 10 行。谁能看到我在代码中做错了什么?谢谢 :)

4

3 回答 3

3

你的代码的问题count($file)是没有按照你的想法做。$file只是一个文件句柄资源,而不是一个数组。你最终会比较$i >= -11,这当然总是会评估为true/

如果您只想使用 linux 来获取最后十行(不确定您是否在 linux 上),您可以尝试这样的操作:

$initial_csv = 'csvfile.txt';
$truncated_csv ='csvfile_trun';
$number_of_lines_from_end = 10;
shell_exec('tail -n ' . $number_of_lines_from_end . ' ' . $initial_csv . ' > ' . $truncated_csv);
$file=fopen($truncated_csv,"r");
$pagelist=array();
$i=0;
while (!feof($file)) {
    $pagelist[$i]=fgetcsv($file);
    $i++;
}
fclose($file)

或者,如果您不介意将整个文件放在内存中(即文件将保持很小),您可以将整个文件读入这样的数组。

$csv = 'csvfile.txt';
$number_of_lines_from_end = 10;
$file_array = file($csv);
$line_count = count($file_array);
$start = $line_count - $number_of_lines_from_end - 1;
$pagelist=array();
for ($i = $start; $i < $line_count; $i++) {
    $pagelist[]=fgetcsv($file);
}
于 2012-12-15T00:12:18.710 回答
0

另一个实现,为了它的乐趣(迈克的tail可能是最快的):

$storage  = new SPLFixedArray(10);
$i = 0;
while(($line = fgets($file)) && ++$i) {
    $storage[$i%10] = $line;
}
$storage = $storage->toArray();
//switch if order is important;
$prepend = array_splice($storage,($i%10)+1,10 - ($i%10));
array_splice($storage,0,0,$prepend);
//interpret csv
$result = array_map('str_getcsv',$storage);
于 2012-12-15T00:34:54.743 回答
-1
$file=fopen(csvfile.txt,"r");    
$pagelist= [];                  
$temp = fgetcsv($file);          
array_merge($pagelist, $temp);   
fclose($file);                              
print_r($pagelist);                         
$lastten = array_slice($pagelist, -10, 10); 
print_r($lastten);

*我可能对切片偏移和限制有误。

于 2012-12-15T00:13:39.317 回答