Adventures in Groovy – Part 38: Challenge Accepted (Exporting Data With The System Date In The Filename)
I had a great question today so challenge accepted! A reader asked if it was possible to run a data export and have the system date in the file name. The answer is very simply, yes. I don’t have any content around the question, so I will answer it in two ways.
Option One – Groovy
If you have read any of the pieces of this series, you know how excited I am about Groovy. Yeah, I know, Groovy can do everything. You are tired of hearing me say that. I know it can’t do everything, but it comes close! In Exporting Data in PBCS With Business Rules, I talk about exporting data with a business rule. In Part 1 of my Groovy Series, I lay out how to execute a business rule with Groovy and how you can alter the Essbase calculation at run time. If we put these two concepts together, we can set the name of the export to anything we want, even a system date.
The Date() method will return a date in a default format and inside a Groovy calculation it uses GMT time. Since I am in EST, it is always 5 hours ahead. So, if the date is printed at 5PM EST, the results is Wed Jan 16 22:00:00 GMT 2019. This can be altered by formatting it to just about anything your heart desires. I am sure you see where I am going. If you google “format date Groovy” it will list nearly 50 options for date and time, AM/PM or military time, month as a number, 3 digit abbreviation, or the whole month, as examples. For this example, the file to be just the system date.
Def currentDate = new Date().format("MM_dd_yyyy") // this returns the a two digit month, two digit day, and four digit year, separated by underscores
If you don’t want GMT, there is a trick. The date method accepts a date. It can be a fully qualified date like “1/15/19 22:00:00” or you can enter the seconds from January 1, 1970, 00:00:00 GMT. This might sound crazy but in a Groovy calculation you can use currentTimeMillis() to get exactly that. Again, since this is GMT, and EST is the want, add 3,600,000 milliseconds for each hour you want to change from GMT. If these two methods are combined, the appropriate time can be obtained.
def adjEST = currentTimeMillis() + (3600000 * -5) def currentDate = new Date(adjEST).format("MM_dd_yyyy") // This would give me the date 5 hours behind GMT
Now that we have the system date (and this is obviously my interpretation because I want it represented in my home time zone), we can combine this with the examples referenced above to export the data to a file with a name that includes the “system date.”
If you don’t know, the last string in a Groovy calculation is actually submitted to the calculation engine. A stringbuilder is not required as noted in the examples. The drawback of this is that we don’t have the option to log the actual calculation script. This is more helpful when debugging and isn’t always critical to have documented in a production application via a log. So, here goes! The only change from the example is that we define a date variable as mm_dd_yyyy and pass that to the calculation.
// Get the date in EST and format as needed def adjEST = currentTimeMillis() + (3600000 * -5) def currentDate = new Date(adjEST).format("MM_dd_yyyy") // Pass the calculation with the currentDate variable as the file name """ SET DATAEXPORTOPTIONS { DataExportLevel LEVEL0; DataExportDynamicCalc OFF; DataExportNonExistingBlocks OFF; DataExportDecimal 4; DataExportPrecision 16; DataExportColFormat ON; DataExportColHeader Period; DataExportDimHeader ON; DataExportRelationalFile ON; DataExportOverwriteFile ON; DataExportDryRun OFF; } FIX(@Relative("Account", 0), @Relative("Years", 0), @Relative("Scenario", 0), @Relative("Version", 0), @Relative("Entity", 0), @Relative("Period", 0), @Relative("<em>custom_dim_name_1</em>", 0), @Relative("<em>custom_dim_name_1</em>", 0), @Relative("<em>custom_dim_name_1</em>", 0)) DATAEXPORT "File" "," "/u03/lcm/${currentDate}.txt" ""; ENDFIX """
This would produce a file in the inbox named 01_16_2019.txt. By adding a parameter and formatting it to the date we want the file to be named, we have our solution. Two additional lines and adding the parameter to the Essbase calculation is all that is required.
Part Two – Without Groovy
This is a little more difficult without Groovy. I have not found a way to use something like the following as the file name. If a reader sees this and knows of a way a way to do this, please share it and post a comment.
@CONCATENATE (@CONCATENATE ("/u03/lcm/", @FORMATDATE(@TODAY(),"mm_dd_yyyy")),".txt")
I assume in the original question that the ask is really not to have a file in the inbox with a specific name. By using EPMAutomate and execute the calculation with a static name, the file can be download and renamed. A simple PowerShell script could be used to rename the file. If there really is a need to have this in the inbox, it can be uploaded. I don’t know of any method that exists to rename an existing file with EPMAutomate.
$localFile = "c:\PBCS_Downloads\" $exportFileName = "DataExport.txt" Start-Process "epmautomate downloadfile ""$exportFileName""" # Assume the script is executed from c:\PBCS_Downloads\ or the file is moved to this folder $fileObj = get-item "c:\PBCS_Downloads\dataexport.txt" rename-item "$($fileObj.FullName)" "$(Get-Date -Format "MM_dd_yyyy")$($fileObj.Extension)" Start-Process "epmautomate uploadfile ""$($fileObj.DirectoryName)\$(Get-Date -Format ""MM_dd_yyyy"")$($fileObj.Extension)"""
Challenge Completed
Another challenge accepted has been easily completed. Keep them coming!
Is TimeCategory allowed inside EPBCS?
As in:
use( groovy.time.TimeCategory ) {
currentDate = (new Date() – 5.hours).format(“MM_dd_yyyy”)
}
A lot of the class expressions are not permitted to be used. I assume they error on the side of caution on what we can instantiate and what we can’t. I have run into other things that would have been nice to have access to that we don’t. So, unless I am not doing something correctly, we don’t. I have tried to use this and some other calendar functions in the past with no success. Thanks for the question and initiating this conversation.
Is there any way in groovy to create a log file and store in Outbox or send through mail.
Not yet, but writing to the inbox is coming. You can currently write a grid to a file in the inbox for testing/validation, but that is it.
Hi, can you know if I can export labels from a smartlist like export data function in the application does with groovy?
I just need to export accounts alias and the smartlist labels, is possible do it with groovy?
Thanks in advanced!
I Have not tested it but there is a method on a grid export the grid to the inbox. You could put the account smartlist in the grid and export that and see if that gives you the labels.
The other way would be to run a rest api call to query the smartlist sand save that to a file.
Short answer is yes, but the long answer is I don’t think you can do it in a calc without calling the expert with rest api.
I don’t know what the use case is so I am guessing as to why you want it.