Hi all,
I have a SAS program which reads in Excel spreadsheets and moves the files listed within from one location to another.
As part of this program, I am trying to build a ReadMe file which:
1 Is a text file
2 Lives in the original directory of the file
3 Contains:
a) List of files moved
b) Starting loc
c) Ending loc
d) Date
I have a sequence which is working, BUT in doing runs, it is getting some error messages if either the directory or file name has weird characters (I've seen comma and hyphen as examples - there could probably be others):
Here is what I have. It is using values in the data for directory, new directory, and file name to build everything. What I'd like is advice on how to modify the sequence so it is robust to these weird characters:
If your files have commas in them, it's likely that you will need to add some macro quoting functions. You could try replacing all of your calls to %scan with %qscan, and that might do it.
Can you run your code with options MPRINT turned on, and post the log from processing a file with problematic characters in the name that shows the name of the file, and also shows the error messages?
Please share example input and expect output.
A quick scan of the code makes it look like you are starting from a dataset named xl_file_move and creating a dataset named readme which is then written to a tab delimited text file.
I do not understand why you are moving ANY of this data into macro variables. You could most likely do this all with simple data steps and then commas or hyphens will not cause any trouble at all.
Looks like you just want to run something like this data step.
data _null_;
set xl_file_move ;
by directory new_loc ;
length readme $256 ;
date_string = "%sysfunc(date(),yymmdd10.)";
readme = cats(directory, '/readme_',date_string,'.txt');
file readme filevar=readme ;
if first.new_loc then do ;
row=0;
put 'The following files have been moved from ' directory 'to ' new_loc 'on ' date_string ;
end;
row+1;
put row fname ;
run;
Although it would be better if the date_string was actually one of the variables in the source list of files. In that case you would want to add DATE_STRING to the BY statement between DIRECTORY and NEW_LOC so that all of the files from DIRECTORY on the same date are documented in the same text file.
Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.