当列中的文本很长时,如何使列成为自动宽度?
我用这个代码
Worksheet.Column(colIndex).AutoFitColumn() 'on all columns'
Worksheet.cells.AutoFitColumns()
Worksheet.Column(colIndex).BestFit = True 'on all columns'
这些方法都不起作用
有没有办法让它发挥作用?
注意:我的一些文本使用Unicode。
使用AutoFitColumns
,但你必须指定单元格,我假设整个工作表:
VB.net
Worksheet.Cells(Worksheet.Dimension.Address).AutoFitColumns()
C#
Worksheet.Cells[Worksheet.Dimension.Address].AutoFitColumns();
请注意,填写工作表后需要调用此方法。
我已将此代码与EPPlus的3.1.3.0版本一起使用,它正在工作:
worksheet.Column(1).AutoFit();
其中工作表是引用我在代码中创建的工作表的变量(不是具有静态方法的类!)。
显然,填写完列后必须调用此方法。
我知道这是一个老问题,但我使用下面的代码,它似乎直接解决了你试图做的事情。
using (var xls = new ExcelPackage())
{
var ws = xls.Workbook.Worksheets.Add("Some Name");
//**Add Column Names to worksheet!**
//**Add data to worksheet!**
const double minWidth = 0.00;
const double maxWidth = 50.00;
ws.Cells.AutoFitColumns(minWidth, maxWidth);
return pkg.GetAsByteArray();
}
我知道有点晚了,但今天我遇到了同样的问题。如果你有一个worksheet.DefaultColWidth
defined,它将无法正常工作。我已删除该行并添加了Worksheet.cells.AutoFitColumns();
,现在可以使用了。
只是想指出你可以在不指定范围的情况下调整单元格,只需确保在格式化所有列之后调用它:
worksheet.Cells.AutoFitColumns()
它对我来说很好。
尝试:
ExcelWorksheet wsSheet1 = ExcelPkg.Workbook.Worksheets.Add("Sheet1");
wsSheet1.Cells[wsSheet1.Dimension.Address].AutoFitColumns();
ExcelPkg.SaveAs();
您需要计算宽度。库中没有可以按预期工作的自动调整功能。
Autofitcolumn不适用于包含文本和带公式的单元格。
请查看http://epplus.codeplex.com/discussions/218294?ProjectName=epplus,了解如何解决问题。
不得不使用worksheet.Column(1).AutoFit(0);
AutoFit()没有做到这一点。
我使用它并且运行良好。
Dim objExcel As New ExcelPackage
Dim Sheet As ExcelWorksheet = objExcel.Workbook.Worksheets.Add("SheetName")
Sheet.Cells("B1:BN").AutoFitColumns()