EPPlus字体系列不受影响

Var*_*yee 12 c# asp.net-mvc-4 epplus

我正在使用asp.net MVC 4和epplus作为nuget包,用于将我的数据导出到excel文件中.我这样做如下:

        var excel = new ExcelPackage();
        var workSheet = excel.Workbook.Worksheets.Add("Consumption");
        workSheet.View.RightToLeft = true;
        for (var col = 1; col <= totalCols; col++)
        {
            workSheet.Cells[1, col].Style.Font.Name = "B Zar";
            workSheet.Cells[1, col].Style.Font.Size = 16;
            workSheet.Cells[1, col].Style.Font.Bold = true;
            workSheet.Cells[1, col].Style.Fill.PatternType = OfficeOpenXml.Style.ExcelFillStyle.Solid;
            workSheet.Cells[1, col].Style.Fill.BackgroundColor.SetColor(System.Drawing.Color.LightGray);
            workSheet.Cells[1, col].Value = ds.Tables[0].Columns[col - 1].ColumnName;
        }

        for (var row = 1; row <= totalRows; row++)
            for (var col = 0; col < totalCols; col++)
            {
                workSheet.Cells[row + 1, col + 1].Style.Font.Name = "B Zar";
                workSheet.Cells[row + 1, col + 1].Style.Font.Size = 11;
                workSheet.Cells[row + 1, col + 1].Value = ds.Tables[0].Rows[row - 1][col];
            }

        workSheet.Cells[1, 1, totalRows + 1, totalCols].Style.Border.Top.Style =
            workSheet.Cells[1, 1, totalRows + 1, totalCols].Style.Border.Bottom.Style =
                workSheet.Cells[1, 1, totalRows + 1, totalCols].Style.Border.Right.Style =
                    workSheet.Cells[1, 1, totalRows + 1, totalCols].Style.Border.Left.Style =
                        OfficeOpenXml.Style.ExcelBorderStyle.Thin;
        workSheet.Cells[1, 1, totalRows + 1, totalCols].Style.HorizontalAlignment = OfficeOpenXml.Style.ExcelHorizontalAlignment.Center;

        using (var memoryStream = new MemoryStream())
        {
            Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
            Response.AddHeader("content-disposition", "attachment;  filename=Consumptions.xlsx");
            excel.SaveAs(memoryStream);
            memoryStream.WriteTo(Response.OutputStream);
            Response.Flush();
            Response.End();
        }
Run Code Online (Sandbox Code Playgroud)

问题是,当我下载文件并在Excel 2016上打开它时,字体系列不受影响,但在字体名称框中,它会出现.如果我专注于组合框并按Enter键,则字体系列将受到影响.

我怎么解决这个问题 ?

VDW*_*WWD 18

试试这个:

var allCells = sheet.Cells[1, 1, sheet.Dimension.End.Row, sheet.Dimension.End.Column];
var cellFont = allCells.Style.Font;
cellFont.SetFromFont(new Font("Times New Roman", 12));
cellFont.Bold = true;
cellFont.Italic = true;
Run Code Online (Sandbox Code Playgroud)

  • sheet.Cells [sheet.Dimension.Address]是获取整个文档范围的一个不错的捷径。 (2认同)

小智 6

workSheet.Cells.Style.Font.Name = "Arial Narrow";
workSheet.Cells.Style.Font.Size = 10;
Run Code Online (Sandbox Code Playgroud)

这将影响所有


小智 1

当我们使用阿拉伯语或波斯语字体时,EPPlus 中会发生此问题,我们必须使用字符集并且它可以工作。

var allCells = workSheet.Cells[1, 1, workSheet.Dimension.End.Row, 
workSheet.Dimension.End.Column];
var cellFont = allCells.Style.Font;
cellFont.SetFromFont("B Nazanin", 16);
cellFont.Charset = 178;
Run Code Online (Sandbox Code Playgroud)