UDF help wanted

henryg

Board Regular
Joined
Oct 23, 2008
Messages
152
Office Version
  1. 365
Platform
  1. Windows
I have set up the UDF below to put the last file saved date into the active cell; and I also want to change the cell format to "dd-mm-yyyy" but it does not change whatever I do.

Here is the simple UDF:

Function LastSavedDate() As Date ' I tried "As String" too.

lastSaved = FileDateTime(ActiveWorkbook.FullName)
LastSavedDate = lastSaved

ActiveCell.NumberFormat = "dd/mm/yyyy"

End Function

I have tried various permutations, searched online and tried ChatGPT but I cannot get it to work.

Help appreciated.

Henry
 

Excel Facts

Why are there 1,048,576 rows in Excel?
The Excel team increased the size of the grid in 2007. There are 2^20 rows and 2^14 columns for a total of 17 billion cells.
Rather than trying to format the cell, format the value?
VBA Code:
Function LastSavedDate() As Date
LastSavedDate = format(filedatetime(activeworkbook.FullName),"dd/mm/yyyy")
End Function
 
Upvote 0
Rather than trying to format the cell, format the value?
VBA Code:
Function LastSavedDate() As Date
LastSavedDate = format(filedatetime(activeworkbook.FullName),"dd/mm/yyyy")
End Function
Sadly that doesn’t work either.

I can live with manually formatting the cell, it’s only once per use, but it’s irritating me.
 
Upvote 0
I put this in the immediate window
sheets("Sheet1").Range("A1") = format(filedatetime(activeworkbook.FullName),"dd/mm/yyyy")

and got this
1716654841307.png


Did you step through your code and check variables/references as you go?
 
Upvote 0
This works:

Function LastSavedDate() As String
Dim lastSaved As String
lastSaved = Format(FileDateTime(ThisWorkbook.FullName), "dd/mm/yyyy")
LastSavedDate = lastSaved
End Function

I have no idea why this works and your original one didn't - it came after asking MRX.CL/GPT to review my earlier code, albeit after some miss-steps.

I hadn't used the immediate window; too much of a tyro at VBA.

It works so I'm happy. Of course, it means every file I save needs to be macro-enabled which may not be such a good idea, but then it's my own files.

Thanks for the help.

Henry
 
Upvote 0
I would say it's because
a) you use undeclared variables (like LastSaved) which makes them variant data type, which means they can hold anything
b) format function changes data type to string (at least it does so in Access vba). That means
c) LastSaved is a string that you assign as the function return value, which is a date data type.

Now that you've made both of them strings, it works as intended. I once read a post that says "if you don't use Option Explicit in all of your modules, you deserve the grief you get" and I wholeheartedly agree. If you had declared LastSaved as a string you should have raised an error; probably Type Mismatch (13?). That would have led the way.
 
Upvote 0

Forum statistics

Threads
1,224,828
Messages
6,181,204
Members
453,022
Latest member
RobertV1609

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top