此文档仅供参考
想要实现:
某些情况下想实现导出后的文档不需要显示隐藏的列,需要删除。
实现方案:
需要写服务端宏代码实现,实现代码如下:
function main(spreadsheetReport) { if (spreadsheetReport.outputType != "EXCEL2007") return; spreadsheetReport.cacheable = false; var workbook = spreadsheetReport.workbook; var worksheet = workbook.worksheets.get(0); worksheet.getCells().deleteColumn(0); }
注:如果隐藏的列有被其它单元格引用,可以使用下面的报表宏实现导出删除。
function main(spreadsheetReport) { if (spreadsheetReport.outputType != "EXCEL2007") return; spreadsheetReport.cacheable = false; var workbook = spreadsheetReport.workbook; var worksheets = workbook.worksheets; for (var i = 0; i < worksheets.count; i++) { var worksheet = worksheets.get(i); var cells = worksheet.cells; var maxDisplayRange = cells.maxDisplayRange; for (var x = 0; x < maxDisplayRange.rowCount; x++) { for (var y = 0; y < maxDisplayRange.columnCount; y++) { var cell = cells.get(x, y); if (cell.isFormula()) { cell.value = cell.value; } } } } worksheet.getCells().deleteColumn(3); }