我試圖使用NPOI 2.1.3.1從某些數據庫數據創建Excel文件。但是,正在創建的文件已損壞。 Excel拒絕打開它,並將其更改爲ZIP並嘗試將其解壓縮,這也會導致Windows和WinRAR中的錯誤。我讀過的其他線程表示升級到2.1.3.1,因爲它修復了XLSX創建的一些問題,但這根本不是真的。我也讀過它與它如何壓縮文件有關,但似乎沒有任何控制它的能力。我希望有人可以用下面我的代碼點我在正確的方向:NPOI 2.1.3.1生成損壞的XLSX文件
public byte[] GetExcelFile(
QueryModel query) {
var orders = Mapper.Map<IList<ExcelListModel>>(Context.Orders.Where(
o =>
o.DateOrdered >= query.Start
&& o.DateOrdered <= query.End));
var workbook = new XSSFWorkbook();
var sheet = workbook.CreateSheet();
for (int i0 = 0, l0 = orders.Count, r = 0; i0 < l0; i0++) {
var order = orders[i0];
for (int i1 = 0, l1 = order.Products.Count; i1 < l1; i1++, r++) {
var row = sheet.CreateRow(r);
var product = order.Products[i1];
row.CreateCell(0).SetCellValue("");
// ...
row.CreateCell(18).SetCellValue("");
}
for (int i1 = 0, l1 = order.Bonuses.Count; i1 < l1; i1++, r++) {
var row = sheet.CreateRow(r);
var bonus = order.Bonuses[i1];
row.CreateCell(0).SetCellValue("");
// ...
row.CreateCell(18).SetCellValue("");
}
}
var memoryStream = new MemoryStream();
workbook.Write(memoryStream);
return memoryStream.ToArray();
}