Board logo

标题: 求助:日志输出 [打印本页]

作者: sybwyn     时间: 2010-12-8 13:36    标题: 求助:日志输出

想记录每次copy了哪些文件,日志的填写有点问题,头大,想请高人看看

xcopy 服务器路径 本机路径  >> C:\update_log.txt

两种情况:
1、服务端文件全部更新到本机,日志显示:恭喜你,本机已经在“年-月-日 星期X 点-分-秒”更新了所有文件

2、如果有程序占用了部分文件而无法更新覆盖,日志显示:有以下文件因被本地程序占用未成功更新,列出文件名

达人给点指导,谢谢!

[ Last edited by sybwyn on 2010-12-8 at 13:46 ]
作者: Hanyeguxing     时间: 2010-12-9 00:12
按照楼主的目的,必须对xcopy使用/c参数!否则复制会被 %ERRORLEVEL%=4 共享侵犯错误终止。
而使用了 /c 参数后,xcopy 不会返回错误,所以只能从2句柄中读取,而该句柄仅显示错误类型,不显示具体哪个文件出错,所以同时输出1句柄(因为/q是禁止1句柄的,所以不能用),然后对 错误.log 进行解析。
当然还有方法二,就是以1句柄输出的文件列表为参照,比较目标文件的时间以判断是否被修改。
@echo off&setlocal enabledelayedexpansion
set "xing=C:\update_log.txt"
echo a|xcopy "\\服务器路径" "C:\本机路径" /cfskrh>han.ye 2>&1
for /f "tokens=1* delims=>" %%a in (han.ye) do call:han "%%a" "%%b"
if "%gu%"=="" >>%xing% echo 恭喜你,本机已经在“%date% %time%”更新了所有文件
del /q han.ye
exit
:han
set han=%~1
if "%han:~0,3%"=="改写 " goto:ye
if "%han:~0,3%"=="复制了" goto:ye
(if "%han:~0,3%"=="共享侵" (
    if "!gu!"=="" echo 有以下文件因被本地程序占用未成功更新(%date% %time%):
    echo !ye:~1!
    set gu==
))>>%xing%
:ye
set ye=%~2

作者: sybwyn     时间: 2010-12-9 00:25
真是太感谢你了!!!拜谢!再拜谢!!!
作者: yf6122010     时间: 2010-12-9 10:13
学习了!
作者: sybwyn     时间: 2010-12-9 12:26
想再请教一下,我想把已经成功复制的文件名写进一个txt文件里边去,例如

xcopy %服务器路径% %本地路径% /discehy > C:\1.txt

在上面的代码中应该怎么加一条进去呢

谢谢!
作者: Hanyeguxing     时间: 2010-12-9 12:47
这里的成功复制是指“服务端文件全部更新到本机”?
还是指无论全部与否,都把复制过的输出?
上加到2楼代码里,还是加到:
xcopy %服务器路径% %本地路径% /discehy > C:\1.txt
中去?

[ Last edited by Hanyeguxing on 2010-12-9 at 13:10 ]
作者: sybwyn     时间: 2010-12-9 13:32
非常抱歉,怪我没描述清楚
1、“成功复制”是指无论全部复制还是部分复制,都把复制过的文件名输出到一个txt文件中去
2、是要在2楼的代码里边修改一下,实现上面的功能
作者: Hanyeguxing     时间: 2010-12-9 14:29
代码未测试:
@echo off&setlocal enabledelayedexpansion
::设置日志
set "xing1=C:\update_log.txt"
::设置复制列表
set "xing2=C:\1.txt"
::设置错误消息组
set "@共享侵=="

echo a|xcopy "\\服务器路径" "C:\本机路径" /cfskrh>han.ye1 2>&1
for /f "tokens=1* delims=>" %%a in (han.ye1) do call:han "%%a" "%%b"
if "%gu%"=="" >>%xing1% echo 恭喜你,本机已经在“%date% %time%”更新了所有文件
>>%xing2% findstr /v /l /g:han.ye2 han.ye3
del /q han.ye*
exit
:han
set han=%~1
set han=%han:~0,3%
if "%han%"=="改写 " goto:ye
if "%han%"=="复制了" goto:ye
if defined @%han% (
    if "!gu!"=="" >>%xing1% echo 有以下文件因被本地程序占用未成功更新(%date% %time%):
    >>%han.ye2% echo !ye:~1!
    set gu==
) else >>han.ye3 echo %~2
:ye
set ye=%~2

作者: sybwyn     时间: 2010-12-9 16:24    标题: 测试8楼高人的代码

以下2种场景,8楼高人的代码经过N此测试,得出结果如下:

第一种场景:本地文件未被程序占用:日志C:\update_log.txt填写正确,日志C:\1.txt产生了文件但是内容为空

第二种场景:本地文件按被程序占用:日志C:\update_log.txt显示“有以下文件因被本地程序占用未成功更新(%date% %time%)”,但是文件内容为空;日志文件C:\1.txt内容为空

老大再帮忙看看,谢谢!

[ Last edited by sybwyn on 2010-12-9 at 19:33 ]
作者: a081910     时间: 2010-12-10 15:12
学习一下了!