I want to format dates in a Table column in Excel 365 Web using a custom format. I can format a cell but not the cell value picked up in a variable or array.
function main(workbook: ExcelScript.Workbook) {
let selectedSheet = workbook.getActiveWorksheet();
// Set number format for range A2 on selectedSheet
// selectedSheet.getRange("A2").setNumberFormatLocal("yyyy-mmm");
let v = selectedSheet.getRange("A2").getValue() ;
console.log(v);
}
I want the dates to show up as yyyy-mmm
. Can anyone show how to custom date format an array of values?
Depending on what you want to do, there are two options.
Format in Script Only
My experience with Javascript and date formatting has never been a favourable one, not like Excel or any of the Microsoft formatting options across it's platforms you typically have access to.
When it comes to working with Javascript dates, all I could find was cobbling the format together by using a string based approach.
You first need to turn the Excel date into a JS date and then do the work from there.
Try this ...
Microsoft actually give you a small headstart with this documentation which I have applied to my answer ...
https://learn.microsoft.com/en-us/office/dev/scripts/resources/samples/excel-samples#dates
It's not ideal but (I believe) it's your best option.
To apply that to entire range/column, you'd need to use a loop which is far from ideal.
Apply Format to Entire Column
It's pretty simple ...
... you just need to know which column you want to format it on.