标题: 请问如何在批处理文件中引入系统日期作为生成的文件名?
[打印本页]
作者: rocketer
时间: 2006-12-1 00:48
标题: 请问如何在批处理文件中引入系统日期作为生成的文件名?
请问如何在批处理文件中引入系统日期作为生成的文件名?
本人每天做数据库MySQL的备份,打dos命令:
mysqldump -uroot -proot -B qyzx > c:\qyzx_mysql.sql
然后手工改文件名为带当天日期的文件名,如:qyzx_mysql_20061128.sql
请问怎么在批处理文件名中取系统当天日期自动加入到命令中呢?
进一步,有没有取昨天,前天,明天后天等相对日期运算的办法呢?
另外批处理命令属于什么语法?要看什么类型的书呢?想学学。
本人初学者,几乎不会写批处理,只会把Dos命令简单填入bat文件中。
请高手指教,谢谢!~~~~~~~~~~
作者: youxi01
时间: 2006-12-1 02:30
mysqldump -uroot -proot -B qyzx > c:\qyzx_mysql_%date::=-%.sql
作者: rocketer
时间: 2006-12-1 04:03
标题: 谢谢,但是没成功,似乎哪个地方........
谢谢,但是没成功,似乎哪个地方........
Microsoft Windows 2000 [Version 5.00.2195]
(C) 版权所有 1985-2000 Microsoft Corp.
D:\>mysqldump -uroot -proot -B qyzx > c:\qyzx_mysql_%date::=-%.sql
mysqldump: Got error: 1102: Incorrect database name '2006-11-30.sql' when select
ing the database
D:\>myrun1
D:\>mysqldump -uroot -proot -B qyzx 2006-11-30.sql 1>c:\qyzx_mysql_星期四
mysqldump: Got error: 1102: Incorrect database name '2006-11-30.sql' when select
ing the database
D:\>
作者: rocketer
时间: 2006-12-1 04:05
标题: ??
生成的文件是
qyzx_mysql_星期四
没有扩展名
作者: rocketer
时间: 2006-12-1 04:10
标题: 谢谢
我加了个双引号,改为
mysqldump -uroot -proot -B qyzx > "c:\qyzx_mysql_%date::=-%.sql"
得到的备份文件名为:
qyzx_mysql_星期四 2006-11-30.sql
基本可以了,谢谢!!!但有没有更好一点的,
把汉字星期四和后面的空格甚至日期之间的横线去掉的写法呢?
也就是按照20061130的日期格式呢?谢谢
因为想生成的文件名标准一点,可以直接在命令行上敲,
文件名有汉字和空格就不太好了,谢谢
[
Last edited by rocketer on 2006-11-30 at 04:34 PM ]
作者: ccwan
时间: 2006-12-1 04:29
for /f "tokens=1-4 delims=:-" %%i in ("%date:~0,10%") do set DT=%%i%%j%%k
set DT=%DT: =0%
mysqldump -uroot -proot -B qyzx > c:\qyzx_mysql_%DT%.sql
作者: rocketer
时间: 2006-12-1 05:20
标题: 谢谢!
但我试了一下,结果是
qyzx_mysql_星期四020061.sql
似乎是差在哪个小小的地方???
还请高手继续帮我看看???
可以把 mysqldump -uroot -proot -B qyzx
换成个 dir
看看生成的文件名是否是希望的,谢谢,
我可是看不懂了,慢慢学
作者: ccwan
时间: 2006-12-1 06:01
不好意思,我们的时间格式不一样,("%date:~0,10%") 改为("%date:~0,13%") 再试试
作者: rocketer
时间: 2006-12-1 06:55
标题: 谢谢!
这次是
qyzx_mysql_星期四02006113.sql
要是星期四后面那个零跑到最后就对了,
哦?原来还有不同时间格式的问题啊?我如何知道时间格式呢?
最终弄好后换台机器运行还有乱的可能么?
另外汉字是消不掉的咯?????
谢谢
作者: ccwan
时间: 2006-12-1 07:07
win2000测试通过:
for /f "tokens=1-4 delims=:-" %%i in ("%date:~0,14%") do set DT=%%i%%j%%k%%l
set DT=%DT: =%
mysqldump -uroot -proot -B qyzx > qyzx_mysql_%DT%.sql
作者: rocketer
时间: 2006-12-1 08:10
标题: 谢谢!!!
成功了
qyzx_mysql_星期四20061130.sql
谢谢您!!!
那个星期看来是消掉比较麻烦了,不过现在已经很不错了,再次感谢!!!
现在看不明白,慢慢学吧。
作者: ccwan
时间: 2006-12-1 20:49
要去掉星期几,将代码改为:
for /f "tokens=1-4 delims=:-" %%i in ("%date:~3,14%") do set DT=%%i%%j%%k%%l
set DT=%DT: =%
mysqldump -uroot -proot -B qyzx > qyzx_mysql_%DT%.sql
你可以根据两次代码的不同,来分析如何实现,就会明白了。
作者: rocketer
时间: 2006-12-2 09:55
标题: 太强了!!!
太谢谢了!!!此贴我已珍藏,再次感谢!!!
作者: tao0610
时间: 2006-12-3 03:54
xp sp2
set name=%date:~0,-4%
mysqldump -uroot -proot -B qyzx > qyzx_mysql_%name:-=%.sql
作者: aheng
时间: 2006-12-6 06:32
配合一个软件可以实现 我这里有 要的加我QQ 403188070 我发给你
作者: redtek
时间: 2006-12-6 06:57
在下面贴子里的楼主使用 DATE /T ,经测试Win2000、XP、Win2003在这三个系统中日期格式不变~:)
http://www.cn-dos.net/forum/view ... id=OyfxGj#pid156458