中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: 求助:日志输出 上一主题 | 下一主题
sybwyn
新手上路





积分 12
发帖 12
注册 2010-11-28
状态 离线
『楼 主』:  求助:日志输出

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

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

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

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

达人给点指导,谢谢!

[ Last edited by sybwyn on 2010-12-8 at 13:46 ]

2010-12-8 13:36
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
Hanyeguxing
银牌会员

正在学习中的菜鸟...


积分 1039
发帖 897
注册 2009-3-1
来自 在地狱中仰望天堂
状态 离线
『第 2 楼』:  

按照楼主的目的,必须对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


   此帖被 +1 点积分    点击查看详情   
评分人:【 sybwyn 分数: +1  时间:2010-12-9 00:25




批处理之家 http://bbs.bathome.net/forum-5-1.html
2010-12-9 00:12
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
sybwyn
新手上路





积分 12
发帖 12
注册 2010-11-28
状态 离线
『第 3 楼』:  

真是太感谢你了!!!拜谢!再拜谢!!!

2010-12-9 00:25
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
yf6122010
新手上路





积分 18
发帖 18
注册 2010-12-6
状态 离线
『第 4 楼』:  

学习了!

2010-12-9 10:13
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
sybwyn
新手上路





积分 12
发帖 12
注册 2010-11-28
状态 离线
『第 5 楼』:  

想再请教一下,我想把已经成功复制的文件名写进一个txt文件里边去,例如

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

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

谢谢!

2010-12-9 12:26
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
Hanyeguxing
银牌会员

正在学习中的菜鸟...


积分 1039
发帖 897
注册 2009-3-1
来自 在地狱中仰望天堂
状态 离线
『第 6 楼』:  

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

[ Last edited by Hanyeguxing on 2010-12-9 at 13:10 ]



批处理之家 http://bbs.bathome.net/forum-5-1.html
2010-12-9 12:47
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
sybwyn
新手上路





积分 12
发帖 12
注册 2010-11-28
状态 离线
『第 7 楼』:  

非常抱歉,怪我没描述清楚
1、“成功复制”是指无论全部复制还是部分复制,都把复制过的文件名输出到一个txt文件中去
2、是要在2楼的代码里边修改一下,实现上面的功能

2010-12-9 13:32
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
Hanyeguxing
银牌会员

正在学习中的菜鸟...


积分 1039
发帖 897
注册 2009-3-1
来自 在地狱中仰望天堂
状态 离线
『第 8 楼』:  

代码未测试:
@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




批处理之家 http://bbs.bathome.net/forum-5-1.html
2010-12-9 14:29
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
sybwyn
新手上路





积分 12
发帖 12
注册 2010-11-28
状态 离线
『第 9 楼』:  测试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 ]

2010-12-9 16:24
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
a081910
新手上路





积分 2
发帖 2
注册 2010-12-9
来自 北京
状态 离线
『第 10 楼』:  

学习一下了!

2010-12-10 15:12
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: