У меня есть экспорт в электронную таблицу .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
Сохранение файла Excel с использованием диапазона данных в качестве имени файла в C# ⇐ C#
Место общения программистов C#
1737834690
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);
Подробнее здесь: [url]https://stackoverflow.com/questions/79294059/saving-an-excel-file-using-the-data-range-as-file-name-in-c-sharp[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия