首页 > 解决方案 > 如何解决 Laravel Excel 工作表问题?

问题描述

我在哪里可以找到这个onlySheets方法?

我想从包含名为“客户”的工作表的 Excel 文件中导入数据。

我创建了一个ClientsImport.php文件:

<?php

namespace App\Imports;
use Maatwebsite\Excel\Concerns\WithMultipleSheets;

class ClientsImport implements WithMultipleSheets
{
    // MULTIPLE SHEETS
    public function sheets(): array
    {
        return [
            'clients' => new ClientsSheetImport(),
        ];
    }
    // END MULTIPLE SHEETS
}

然后创建ClientSheetImport.php文件以从给定的 Excel 文件中获取行并验证数据:

<?php

namespace App\Imports;

use Maatwebsite\Excel\Concerns\ToModel;
use Maatwebsite\Excel\Concerns\WithValidation;
// use Maatwebsite\Excel\Concerns\WithHeadingRow;
use Maatwebsite\Excel\Concerns\WithMappedCells;
use App\Client;

class ClientsSheetImport implements ToModel, WithValidation, WithMappedCells
{
  /**
   * @param array $row
   *
   * @return Client|null
   */
  public function model(array $row)
  {
      return new Client([
          'nrc_entrp' => $row['nrc_entrp'],
          'raisoci' => $row['raisoci'],

      ]);
  }

  public function rules(): array {
      return [
        'nrc_entrp'=> 'required|unique:clients|max:20',
        'raisoci'=> 'required|unique:clients|max:100',
      ];
  }
  public function mapping(): array
  {
      return [
        'nrc_entrp' => 'B1',
        'raisoci' => 'B2',
        
      ];
  } // mapping

}

ImportClientController.php我想用这个给定的代码从 Excel 文件(“客户”表“)中导入一张表:

  $import_client = new ClientsImport();
  $import_client->onlySheets('clients');
  Excel::import($import_client, $file_url);

但我收到了这个错误:

Call to undefined method App\Imports\ClientsImport::onlySheets()

我在哪里可以找到这个onlySheets方法?

谢谢

标签: phpexcellaravellaravel-excel

解决方案


我这样做并且它有效。添加这个:

class UserImport implement ...{
use WithConditionalSheets;
 public function conditionalSheets(): array
    {
        return [
            'Sheet1' => new ReadImport(),
        ];
    }
...
}

推荐阅读