使用下面格式获得日期SYSDATE=`date +%e%h%Y_%H:%M | awk '{print $0}'`然后通过日期生成指定的文件名MAINLOG=$JCLPATH/etl_$SYSDATE.log然后通过应用程序调用,如:sas $PVPROGRAM/etlrun.sas -sysparm "$MAINPARA" -log $MAINLOG &
初看没有问题,日志也正常,可惜的是今天是5号,那么它MAINLOG的值将会为***/etl_ 5Jan2006_09:53.log注意看,这个日志文件名中有个空格,所以在程序执行时SAS会报一个无效的文件名,然后就中止执行了
根据UNIX日期输出格式规定:%%文本的 % %a当前区域的星期几的简写 (Sun..Sat) %A当前区域的星期几的全称 (不同长度) (Sunday..Saturday) %b当前区域的月份的简写 (Jan..Dec) %B当前区域的月份的全称(变长) (January..December) %c当前区域的日期和时间 (Sat Nov 04 12:02:33 EST 1989) %d(月份中的)几号(用两位表示) (01..31) %D日期(按照 月/日期/年 格式显示) (mm/dd/yy) %e(月份中的)几号(去零表示) ( 1..31) %h同 %b %H小时(按 24 小时制显示,用两位表示) (00..23) %I小时(按 12 小时制显示,用两位表示) (01..12) %j(一年中的)第几天(用三位表示) (001..366) %k小时(按 24 小时制显示,去零显示) ( 0..23) %l小时(按 12 小时制显示,去零表示) ( 1..12) %m月份(用两位表示) (01..12) %M分钟数(用两位表示) (00..59) %n换行 %p当前时间是上午 AM 还是下午 PM %r时间,按 12 小时制显示 (hh:mm:ss [A/P]M) %s从 1970年1月1日0点0分0秒到现在历经的秒数 (GNU扩充) %S秒数(用两位表示)(00..60) %t水平方向的 tab 制表符 %T时间,按 24 小时制显示(hh:mm:ss) %U(一年中的)第几个星期,以星期天作为一周的开始(用两位表示) (00..53) %V(一年中的)第几个星期,以星期一作为一周的开始(用两位表示) (01..52) %w用数字表示星期几 (0..6); 0 代表星期天 %W(一年中的)第几个星期,以星期一作为一周的开始(用两位表示) (00..53) %x按照 (mm/dd/yy) 格式显示当前日期 %X按照 (%H:%M:%S) 格式显示当前时间 %y年的后两位数字 (00..99) %Y年(用 4 位表示) (1970...) %z按照 RFC-822 中指定的数字时区显示(如, -0500) (为非标准扩充) %Z时区(例如, EDT (美国东部时区)), 如果不能决定是哪个时区则为空 -------------------------------------------------------------------------------可以看出,要改正这一问题,要输出2位的日期,可以通过%d来实现,如下SYSDATE=`date +%d%h%Y_%H:%M | awk '{print $0}'`