Файл экспорта Laravel с динамическим именем

Я запускаю скрипт, который сохраняет собранные данные в csv. Это работает так:

$responce =  Excel::store(new UsersExport($formatted_data), 'fileName.csv', null, \Maatwebsite\Excel\Excel::CSV); 

И это мой класс:

class UsersExport implements FromArray
{
    protected $invoices;

    public function __construct(array $invoices)
    {
        $this->invoices = $invoices;
    }

    public function array(): array
    {
        return $this->invoices;
    }
}

Пока имя файла жестко запрограммировано, и я хочу сделать его динамическим. Он должен меняться с указанием года и месяца каждый раз, когда я запускаю новый экспорт (2020-01.csv или что-то в этом роде). Скрипт работает с двумя параметрами - год и месяц.

protected $signature = 'select:values {--year=} {--month=}';

В предложении where я фильтрую так:

->whereMonth('ut', $this->option('month'))   
->whereYear('ut', $this->option('year'))

Пробовал с

Excel::store(new UsersExport($formatted_data)->withFilename()

Но это не работает... Я пока не нашел ничего похожего на свое решение. Любые идеи о том, как это исправить? Спасибо!

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
1
0
227
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Можешь попробовать этот?

$responce = Excel::store(new UsersExport($formatted_data), now()->format('Y-m').'.csv', null, \Maatwebsite\Excel\Excel::CSV);

Это имя файла с текущим годом и месяцем 2022-10.csv. Игнорирование параметров

Yorkata008 27.10.2022 09:41

ты пробовал Excel::store(new UsersExport($formatted_data), $this->option('month').'-'.$this->option('year'), null, \Maatwebsite\Excel\Excel::CSV);

Lucky Person 27.10.2022 09:46

Да конечно так - $this->option('filename') и добавление опции в команду {--filename}. Но это не очень динамично, не так ли (:

Yorkata008 27.10.2022 09:51
Ответ принят как подходящий

Мое решение: С простой конкатенацией php...

$fileName = $this->option('year')."-".$this->option('month').".csv";

И поместите переменную в экспорт следующим образом: $responce = Excel::store(new UsersExport($formatted_data), $fileName ,null, \Maatwebsite\Excel\Excel::CSV);

Другие вопросы по теме