C# 设置Excel数据自适应行高、列宽的2种情况
程序员文章站
2022-06-18 09:58:35
Excel表格中,由于各种数据的复杂性,可能存在单元格中的数据字号大小、数据内容长度不一而出现,列宽过宽、过窄或者行高过大、过小的问题。常见的解决方法是调整行高、列宽。在Microsoft Excel中,在单元格格式设置中可手动设置自适应行高或自适应列宽,但通过代码,我们可以通过方法AutoFitC ......
excel表格中,由于各种数据的复杂性,可能存在单元格中的数据字号大小、数据内容长度不一而出现,列宽过宽、过窄或者行高过大、过小的问题。常见的解决方法是调整行高、列宽。在microsoft excel中,在单元格格式设置中可手动设置自适应行高或自适应列宽,但通过代码,我们可以通过方法autofitcolumns()或者autofitrows()来设置指定数据范围或整个工作表的自适应行高、列宽。这里设置自适应分以下2种情况来进行:
1. 固定数据,设置行高、列宽自适应数据
2. 固定行高、列宽,设置数据自适应行高、列宽(即缩小单元格数据字体大小适应单元格)
使用工具:free spire.xls for .net(免费版)
注:注意在下载安装后,添加引用spire.xls.dll文件,如下图:
【示例1】固定数据,设置行高、列宽自适应数据
step 1: 加载工作簿
//创建一个workbook类的对象,并加载测试文档 workbook workbook = new workbook(); workbook.loadfromfile("sample.xlsx");
step 2: 获取指定工作表
worksheet worksheet = workbook.worksheets[0];
step 3:设置自适应
//设置列宽、行高为自适应(应用于指定数据范围) worksheet.allocatedrange["a1:f15"].autofitcolumns(); worksheet.allocatedrange["a1:f15"].autofitrows(); ////设置列宽、行高为自适应(应用于整个工作表) //worksheet.allocatedrange.autofitcolumns(); //worksheet.allocatedrange.autofitrows();
step 4:保存文档
workbook.savetofile("result.xlsx", fileformat.version2010);
设置效果:
全部代码:
using spire.xls; namespace autofit_xls { class program { static void main(string[] args) { //创建一个workbook类的对象,并加载测试文档 workbook workbook = new workbook(); workbook.loadfromfile("sample.xlsx"); //获取工作表 worksheet worksheet = workbook.worksheets[0]; //设置列宽、行高为自适应(应用于指定数据范围) worksheet.allocatedrange["a1:f15"].autofitcolumns(); worksheet.allocatedrange["a1:f15"].autofitrows(); ////设置列宽、行高为自适应(应用于整个工作表) //worksheet.allocatedrange.autofitcolumns(); //worksheet.allocatedrange.autofitrows(); //保存文档 workbook.savetofile("result.xlsx", fileformat.version2010); system.diagnostics.process.start("result.xlsx"); } } }
【示例2】固定行高、列宽,设置数据自适应行高、列宽
step 1:加载工作簿
//实例化workbook类的对象,并加载测试文档 workbook workbook = new workbook(); workbook.loadfromfile("test.xlsx");
step 2:获取指定工作表
worksheet sheet = workbook.worksheets[0];
step 3: 获取指定数据范围
cellrange cell = sheet.range["a1:c1"];
step 4: 缩小单元格字体以适应列宽
cellstyle style = cell.style; style.shrinktofit = true;
step 5: 保存文档
workbook.savetofile("result.xlsx", excelversion.version2013);
设置结果:
全部代码:
using spire.xls; namespace shrinktexttofitcell_xls { class program { static void main(string[] args) { //实例化workbook类的对象,并加载测试文档 workbook workbook = new workbook(); workbook.loadfromfile("test.xlsx"); //获取第一个工作表 worksheet sheet = workbook.worksheets[0]; //获取指定数据范围 cellrange cell = sheet.range["a1:c1"]; //设置单元格样式(数据缩小以适应单元格) cellstyle style = cell.style; style.shrinktofit = true; //保存文档 workbook.savetofile("result.xlsx", excelversion.version2013); system.diagnostics.process.start("result.xlsx"); } } }
(本文完)