Сохранение файла Excel с использованием диапазона данных в качестве имени файла в C#C#

Место общения программистов C#
Ответить
Anonymous
 Сохранение файла Excel с использованием диапазона данных в качестве имени файла в C#

Сообщение Anonymous »

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

Однако, если в диапазоне дат нет данных, то возвращается ошибка (поскольку оно не может генерировать имя файла, поскольку это требует Диапазон дат и название автомобиля). В идеале я хотел бы, чтобы он генерировал диапазон дат в качестве имени файла, как обычно, даже если нет данных (потенциально генерирует пустую таблицу). Пока что у меня есть -< /p>
[ApiController]
public class CarController(ISender sender, IDataExportService
dataExportService) : BaseController
{
///
/// Get data to be exported from the database for a given car within a given timeframe and converts to Excel (XLSX) format.
/// URL: /excel/{carId}
///
///

///
///
[HttpGet("excel/{carId:int}")]
public async Task CarDataExport(int carId, [FromQuery] ExportCarDataRequest request, CancellationToken cancellationToken)
{
var data = await sender.Send(new ExportAssetDataDataQuery(carId, request), cancellationToken);

var fileName = data.FirstOrDefault().CarName + DateOnly.FromDateTime(DateTime.UtcNow) + ".xlsx";

var memoryStream = dataExportService.ExportToExcel(data, fileName);

return memoryStream;
}
< /code>
Я тогда смог заставить имя файла быть тем, что я хотел, если бы были данные в электронной таблице (см. После еще одного). Однако я немного ошибся с Dapper, чтобы получить Carname в имя файла, когда в электронной таблице нет данных. < /P>
public async Task CarDataExport(int carId,
[FromQuery] ExportCarDataRequest request, CancellationToken
cancellationToken)
{
var data = await sender.Send(new ExportCarDataDataQuery(carId, request), cancellationToken);

var varCar = data.Select (x => x.CarName).Distinct();

String fileName;
if (data.FirstOrDefault().CarName == null)

{
fileName = varCar +
(DateOnly.FromDateTime(DateTime.UtcNow) + ".xlsx";
}
else
{
fileName = data.FirstOrDefault().CarName +
DateOnly.FromDateTime(DateTime.UtcNow) + ".xlsx";
}
}
< /code>
У меня также есть это в запросе < /p>
Public class CarExportDataResponse
{
public CarExportDataResponse() { }

private CarExportDataResponse(carExportData carExportData)
{
CarName = carExportData.CarName;
RegId = carExportData.RegId;
ModelId = carExportData.ModelId;
EngineNum = carExportData.EngineNum;
ServiceType = carExportData.ServiceType;
}
}

И это в ответ
namespace CarYard.Services.Features.Cars.Requests;

public record ExportAssetDataRequest(DateTime DateFrom, DateTime
DateTo, String CarName);
public record GetAssetsRequest(int? PageSize, int? PageNumber);


Подробнее здесь: https://stackoverflow.com/questions/792 ... in-c-sharp
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»