I get a date value from Excel in the form 43201 as an example.
How can I make a date value out of this number that I can use in a condition to evaluate whether this date is less or greater than the current date?
Would be great if somebody could help.
Hi @ lreinhard7,
Do you want to check if the value of date column in the excel table is less or greater than the current date?
I have a date column "starttime" in the excel table, and you could refer to screenshot below to create the flow to check if the value of date column in the excel table is less than the current date.
The expression in the Condition as below:
The flow would run successfully as below:
If you would like to check if the value of date column in the excel table is greater than the current date, you could use the expression in the condition as below:
You could refer to link below to learn more about the workflow definition language:
I tried this using the suggestion
Hello, did you ever find a way to fix the way flow was reading in the values? I've got the same issue now with flow interpreteing cells that are dates as integers.
After a lot of trial and error, I think I have a solution: ticks!
Here's how you construct a date taken from Excel Online:
(I'm taking the date from a loop, but feel free to get it from elsewhere)
And here's how you turn today into ticks:
(you can remove startOfDay if you care about the time, too)
What's going on with the first function: You take Excel's numeric date (days since 1/1/1900), e.g. 43267.234234826 as a float, then multiply it by 864000000000 to turn it into 100s of nanoseconds (i.e. ticks) and, finally, add the difference between 1/1/1900 and 1/1/0001 (in 100s of nanoseconds)
I am having similar issues but I'm also trying to convert the time (e.g. a serial like 43598.802997685 should read 13/05/2019 19:16). I've got the purely the date working, but can't get the time as well.
For context, I'm importing a load of stuff from an excel table into a SharePoint list.
Thank in advance!
AddDays can only add (or substract) whole days. By using int(), you strip your date of the time (but it's mandatory for addDays().
Perhaps you can use the decimal part of the date number and multiply it by 24 (and get the hours), then use the new decimal part and multiply it by 60 (and get the minutes) and, finally, take the last decimal part and multiply again (and round) by 60 (to get the seconds).
For example, 43598.802997685 -> 0.802997685 * 24 = 19,27194444 -> 0,27194444 * 60 =16,3166664 -> 0,3166664 * 60 = 19.
So the whole thing would become 13/05/2019 19:16:19
You can use int() to get the non-decimal part, then sub() it from the initial number, then mul() it by 24/60 and so on.
It's going to get a bit long. Good luck!
To convert excel integers to a date in flow you can use this in your expression:
if(empty(<insert date integers>),'',addDays('1899-12-30',int(<insert date integers>),'MM/dd/yyyy'))
I'm trying all the suggestions in this and other similar threads and nothing is working. I'm using the List Rows Present in a Table action to read an Excel file and create SP list items out of each row. I have 2 date columns in there that keep coming back as integers. I tried the if(empty... solution suggested here and the Flow ran successfully but both dates I was trying to capture just returned blank and wrote nothing to my sharepoint list. I have also tried:
Both of these threw error 'The template language function 'float' (or 'int') was invoked with a parameter that is not valid. The value cannot be converted to the target type.'
What am I missing? My Excel columns are formatted as Short Date. Don't need any time values. Any suggestions? Thanks very much.
EDIT: I should mention that the Excel file being read is stored in a SharePoint Online library
Apologies @abm ~ This Compose expression does actually work:
if(empty(items('ApplyEach_Dates')?['Work Date']),'',addDays('1899-12-30',int(items('ApplyEach_Dates')?['Work Date']),'MM/dd/yyyy'))
I had several rows in my test Excel file. I dug in and found that somehow a couple of my individual date cells were not formatted correctly. This was odd b/c the Number Format was indeed set to "Date" and the fields were right-aligned just like the others -- but somehow they were not actually 'short dates'. When I selected all and switched them to General format, these 2 stuck out. They did not convert to integers but remained looking deceptively like dates. So they were coming in as blank and making the Flow Compose action appear to be incorrect. Many thanks to this thread for the solution.
@RachelRig I appreciate you posted this a while ago but I'm still struggling on my flow. What did you use in the Create Item in SP for the dates? I think that is the bit I'm missing something on. thanks!
In the Create Item action, the value plugged into the date field is the Output of the Compose action directly above.
In my case here, the date field is named Week-Ending and I renamed the Compose action to "ComposeWeekEnding":
Thank you. I thought it should be but the compose option isn't showing up. however I've been trying to find a solution all day so I think it's time I have Automate a rest and try again tomorrow. Really appreciate the quick response!
Hmmm...maybe if Dynamic Content is acting weird, you could just type in the formula yourself in the Expression field. To make it easy, make sure your Compose action name has no spaces or dashes. Then just put it in single quotes.
Explore the latest innovations, learn from product experts and partners, level up your skillset, and create connections from around the world.
Learn to digitize and optimize business processes and connect all your applications to share data in real time.