Можно добавить несколько параметров для импорта Excel? - PullRequest
0 голосов
/ 29 декабря 2018

У меня есть базовая форма, которая содержит загрузку файла Excel и опцию выбора.

Выбор содержит несколько опций.Я хочу передать выбранную опцию пользователя с файлом в мой Excel::import

Я попытался передать другой параметр в свой импорт, но он возвращает ошибку.(должен быть строкой, заданным массивом)

Возможно ли это с помощью импорта Laravel Excel?

Контроллер

public function create(Request $request)
{
    if($request->hasFile('file')) 
    {
        $package = $request->input('package');
        // how can I add $package to my import to insert it to my user model?
        Excel::import(new AccountsImport, $request->file('file'));

        return ['message' => 'Excel has been succesfully uploaded'];
    }
}

AccountsImport

class AccountsImport implements ToCollection, withHeadingRow
{

    public function collection(Collection $rows)
    {
        $rows->each(function($row, $key) {
            Account::create([
                'name'   => $row['student'],
                'email'  => $row['e_mail'],
                // Want it to be possible to add my package here
                //'package' => $package
            ]);
        });
    }
}

1 Ответ

0 голосов
/ 29 декабря 2018

Может быть, вы могли бы передать пользовательские данные в ваш AccountsImport класс?

У вас будет такой массив данных:

$data = [
    'package' => $package, 
    // other data here
]; 

Затем вы сделаете что-то вроде этого:

Excel::import(new AccountsImport($data), $request->file('file'));

Это потребует некоторых изменений в вашем классе импорта,

class AccountsImport implements ToCollection, withHeadingRow
{
    private $data; 

    public function __construct(array $data = [])
    {
        $this->data = $data; 
    }

    public function collection(Collection $rows)
    {
        $rows->each(function($row, $key) {
            Account::create(array_merge([
                'name'   => $row['student'],
                'email'  => $row['e_mail'],
                // Want it to be possible to add my package here
                //'package' => $package
            ], $this->data));
        });
    }
}

Я посмотрел на API Laravel Excel и не смог найти что-то, что могло бы удовлетворить это, но это должно сработать.

...