如何删除laravel excel中的空行?

问题描述 投票:3回答:2

所以我使用Laravel,我使用Laravel excel加载excel / csv文件,但我的文件包含空行,我想删除每一个空行。

这是我的代码:

Excel::selectSheetsByIndex(0)->load($path, function($reader){
       $results = $reader->noHeading()->toArray();
         foreach ($results as $row) {
            //my code
         }
       }, 'UTF-8');

所以,如果有人知道我怎么做,我将非常感激

laravel laravel-4 laravel-excel
2个回答
2
投票

我想你可以这样做

/** @var LaravelExcelReader $data */
        $data = \Excel::load('file.xls', function ($reader) {
            $reader->limitRows(20);
            $reader->ignoreEmpty();
        })->get()->toArray();

        # remove empty rows
        $data = array_filter($data);

0
投票

使用ToCollection方法包装if($row->filter()->isNotEmpty())中的所有内容

    public function collection(Collection $rows)
       {
          foreach($rows as $row) {
            if($row->filter()->isNotEmpty()){
                // you logic can go here

                $user = User::create([
                    'name' => ucwords($row['name']),
                    'class' => $row['class'],
                    ...
                ]);
            }
        }   
       }
© www.soinside.com 2019 - 2024. All rights reserved.