using LanguageExt; using Masuit.Tools.Strings; using Microsoft.AspNetCore.Identity; using NPOI.HPSF; using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Text; using System.Threading.Tasks; using static iText.StyledXmlParser.Jsoup.Select.Evaluator; namespace DS.WMS.Core.Utils { public class ExportFileHelper { // /// // /// 导出 // /// // /// // /// // /// // /// // public async Task Export(List dataLiist, Dictionary colDicts) // { // string filePath = string.Empty; // /* // 1、生成空Excel文件。 // 2、根据colDicts提供的key来匹配字段列表的 // 3、暂存文件,并返回完整文件名 // */ // try // { // string sheetName = ""; // XSSFWorkbook workbook = new XSSFWorkbook(); // ISheet sheet = workbook.CreateSheet(sheetName); // #region Excel模板打印 // //var opt = App.GetOptions(); // //var dirAbs = opt.basePath; // //if (string.IsNullOrEmpty(dirAbs)) // //{ // // dirAbs = App.WebHostEnvironment.WebRootPath; // //} // var fileAbsPath = Path.Combine(dirAbs, printTemplate.FilePath); // //_logger.LogInformation($"准备调用EXCEL生成:id:{id},文件:{printTemplate.FileName}"); // var result = new FileStream(fileAbsPath, FileMode.Open); // var excelwork = new HSSFWorkbook(result); // var sheet = excelwork.GetSheetAt(0); // var entity = await _bookingExcelTemplateRepository.AsQueryable() // .Where(x => x.PId == templateId).OrderBy(x => x.Row).ToListAsync(); // if (entity == null) // { // throw Oops.Bah("当前模板未设置"); // } // for (int _row = 1; _row <= entity.Max(x => x.Row); _row++) // { // if (entity.Where(x => x.Row == _row).Count() > 0) // { // ////获取行 // var row = sheet.GetRow(_row - 1); // if (row != null) // { // for (int _cellNum = 1; _cellNum <= entity.Max(x => x.Column); _cellNum++) // { // if (entity.Where(x => x.Row == _row && x.Column == _cellNum).Count() > 0) // { // var name = entity.Where(x => x.Row == _row && x.Column == _cellNum).Select(x => x.Field).FirstOrDefault(); // if (name.Split('.')[0].ToLower() == "order") // { // foreach (PropertyDescriptor descriptor in TypeDescriptor.GetProperties(order)) // { // var _name = descriptor.Name.ToLower(); // if (name.Split('.')[0].ToLower() == "order" && name.Split('.')[1].ToLower() == _name) // { // var value = descriptor.GetValue(order) != null ? descriptor.GetValue(order).ToString() : ""; // ICell cell = row.GetCell(_cellNum - 1); // if (descriptor.PropertyType.FullName.Contains("DateTime")) // { // value = value != "" ? Convert.ToDateTime(value).ToString("yyyy-MM-dd") : ""; // } // if (cell != null) // { // row.Cells[_cellNum - 1].SetCellValue(value); // } // else // { // row.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // } // if (name.Split('.')[0].ToLower() == "edi") // { // foreach (PropertyDescriptor descriptor in TypeDescriptor.GetProperties(edi)) // { // var _name = descriptor.Name.ToLower(); // if (name.Split('.')[0].ToLower() == "edi" && name.Split('.')[1].ToLower() == _name) // { // var value = descriptor.GetValue(edi) != null ? descriptor.GetValue(edi).ToString() : ""; // ICell cell = row.GetCell(_cellNum - 1); // if (descriptor.PropertyType.FullName.Contains("DateTime")) // { // value = value != "" ? Convert.ToDateTime(value).ToString("yyyy-MM-dd") : ""; // } // if (cell != null) // { // row.Cells[_cellNum - 1].SetCellValue(value); // } // else // { // row.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // } // if (name.Split('.')[0].ToLower() == "userinfo") // { // ICell cell = row.GetCell(_cellNum - 1); // var value = string.Empty; // if (name.Split('.')[1].ToLower() == "username") // { // value = UserManager.Name; // } // if (name.Split('.')[1].ToLower() == "usertel") // { // value = UserManager.TEl; // } // if (name.Split('.')[1].ToLower() == "usermobile") // { // value = UserManager.Phone; // } // if (name.Split('.')[1].ToLower() == "useremail") // { // value = UserManager.Email; // } // if (name.Split('.')[1].ToLower() == "usertenant") // { // value = UserManager.TENANT_NAME; // } // if (cell != null) // { // row.Cells[_cellNum - 1].SetCellValue(value); // } // else // { // row.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // } // } // else // { // ////创建行 // var srow = NpoiExcelExportHelper._.CreateRow(sheet, _row - 1); // for (int _cellNum = 1; _cellNum <= entity.Max(x => x.Column); _cellNum++) // { // if (entity.Where(x => x.Row == _row && x.Column == _cellNum).Count() > 0) // { // var name = entity.Where(x => x.Row == _row && x.Column == _cellNum).Select(x => x.Field).FirstOrDefault(); // if (name.Split('.')[0].ToLower() == "order") // { // foreach (PropertyDescriptor descriptor in TypeDescriptor.GetProperties(order)) // { // var _name = descriptor.Name.ToLower(); // if (name.Split('.')[1].ToLower() == _name && name.Split('.')[0].ToLower() == "order") // { // var value = descriptor.GetValue(order) != null ? descriptor.GetValue(order).ToString() : ""; // if (descriptor.PropertyType.FullName.Contains("DateTime")) // { // value = value != "" ? Convert.ToDateTime(value).ToString("yyyy-MM-dd") : ""; // } // srow.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // if (name.Split('.')[0].ToLower() == "edi") // { // foreach (PropertyDescriptor descriptor in TypeDescriptor.GetProperties(edi)) // { // var _name = descriptor.Name.ToLower(); // if (name.Split('.')[1].ToLower() == _name && name.Split('.')[0].ToLower() == "edi") // { // var value = descriptor.GetValue(edi) != null ? descriptor.GetValue(edi).ToString() : ""; // if (descriptor.PropertyType.FullName.Contains("DateTime")) // { // value = value != "" ? Convert.ToDateTime(value).ToString("yyyy-MM-dd") : ""; // } // srow.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // if (name.Split('.')[0].ToLower() == "userinfo") // { // var value = string.Empty; // if (name.Split('.')[1].ToLower() == "username") // { // value = UserManager.Name; // } // if (name.Split('.')[1].ToLower() == "usertel") // { // value = UserManager.TEl; // } // if (name.Split('.')[1].ToLower() == "usermobile") // { // value = UserManager.Phone; // } // if (name.Split('.')[1].ToLower() == "useremail") // { // value = UserManager.Email; // } // if (name.Split('.')[1].ToLower() == "usertenant") // { // value = UserManager.TENANT_NAME; // } // srow.CreateCell(_cellNum - 1).SetCellValue(value); // } // } // } // } // } // } // var fileFullPath = Path.Combine(App.WebHostEnvironment.WebRootPath, App.GetOptions().Path);//服务器路径 // if (!Directory.Exists(fileFullPath)) // { // Directory.CreateDirectory(fileFullPath); // } // fileName = $"{DateTime.Now.Ticks}.xls";//名称 // ////2023-4-3,根据河川操作要求,文件名只带提单号 // //if (!string.IsNullOrEmpty(order.MBLNO)) // //{ // // fileName = $"{order.MBLNO}.xls";//名称 // //} // //else // //{ // // fileName = $"{order.Id}_{DateTime.Now.Ticks}.xls";//名称 // //} // _logger.LogInformation("导出excel:" + Path.Combine(fileFullPath, fileName)); // var filestream = new FileStream(Path.Combine(fileFullPath, fileName), FileMode.OpenOrCreate, FileAccess.ReadWrite); // excelwork.Write(filestream); // #endregion // } // catch (Exception ex) // { // } // return filePath; // } //} } }