PHPExcel toArray跳过第一个标题行

时间:2015-04-05 10:32:55

标签: php phpexcel phpexcelreader

我正在将一个excel文件上传到网站并处理它以供数据库使用。

我正在使用toArray()函数来获取php数组中的所有行。

但我想跳过第一行(标题标题行)。其余行将存储在数组中。

如何跳过第一行。

注意:我无法使用rangeToArray()函数,因为没有固定的范围来将行放入数组。它是动态的。我想要的就是获取除第一行之外的所有行。

3 个答案:

答案 0 :(得分:9)

Eko回答了问题的一半,你可以使用rangeToArray();但你根本不需要使用循环:

$highestRow = $sheet->getHighestRow(); 
$highestColumn = $sheet->getHighestColumn();

$sheetData = $sheet->rangeToArray(
    'A2:' . $highestColumn . $highestRow,
    NULL,TRUE,FALSE
);

或者,使用toArray(),然后只使用unset返回数组中的第一个元素

答案 1 :(得分:6)

您可以使用array_shift来实现这一点:

$toArray = $worksheet->toArray() 
array_shift($toArray);

答案 2 :(得分:3)

我创建了一个函数来使用PHPExcel读取excel文件,如下所示:

function Read_Excel($fname=null,$isheet=0,$irow=1,$icol='A'){       
        $inputFileName = $fname;        

        try {
            $inputFileType = PHPExcel_IOFactory::identify($inputFileName);
            $objReader = PHPExcel_IOFactory::createReader($inputFileType);
            $objPHPExcel = $objReader->load($inputFileName);
        } catch(Exception $e) {
            die('Error loading file "'.pathinfo($inputFileName,PATHINFO_BASENAME).'": '.$e->getMessage());
        }

        $sheet = $objPHPExcel->getSheet(intval($isheet)); 
        $highestRow = $sheet->getHighestRow(); 
        $highestColumn = $sheet->getHighestColumn();

        for ($row = intval($irow); $row <= $highestRow; $row++){ 
            //  Read a row of data into an array
            $rowData = $sheet->rangeToArray($icol . $row . ':' . $highestColumn . $row,NULL,TRUE,FALSE);
            $rec_tbl[] = $rowData[0];
        }
        return $rec_tbl;
    }

您只需更改函数参数中的$irow=1即可获得所需的行。