Foxtable(狐表)用户栏目专家坐堂 → [求助]设计一段备份的代码


  共有1718人关注过本帖树形打印复制链接

主题:[求助]设计一段备份的代码

帅哥哟,离线,有人找我吗?
Jacksnfeng
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:69 积分:733 威望:0 精华:0 注册:2013/4/6 22:31:00
[求助]设计一段备份的代码  发帖心情 Post By:2017/5/25 16:35:00 [显示全部帖子]

我要设计一个备份功能,所以我用了内部函数backup,代码如下:

If filesys.directoryexists(args0) = False OrElse filesys.directoryexists(args1) = False Then Return Nothing

For Each fns As String In filesys.GetFiles(args0) 'fileNameSource

    Dim fnt As String = args1 & "\" & filesys.GetName(fns) 'fileNameTarget

    If filesys.FileExists(fnt) = False Then

        output.show("step1")

        filesys.copyfile(fns,fnt)

    Else '比较修改时间

        Dim fis As new fileinfo(fns) 'fileinfoSource

        Dim fist As Date = fis.lastwritetime 'fileinfoSourceTime

        Dim fit As new fileinfo(fnt) 'fileinfoTarget

        Dim fitt As Date = fit.lastwritetime 'fileinfoTargetTime

        If fitt < fist Then

            filesys.copyfile(fns,fnt,True)

        End If

    End If

Next

'子文件夹

For Each fns As String In filesys.GetDirectories(args0) 'fileNameSource

dim fnt as string = agrs(1) & fnt.replace(args(0),"")

Functions.Execute(fns,fnt) '递归调用本身 

next

Return Nothing

需要时就调用 Functions.Execute("backup","p:\desktop\Foxtable项目\备份资料\source","p:\desktop\Foxtable项目\备份资料\target")

可是总是出错,求高手完善一下。

另,曾尝试FileSys.CopyDirectory完成此功能,但它没有判断新旧文件编辑时间的功能。源文件夹已删除而目标文件夹还有的文件夹怎样删除?这个功能也没有。

 




 回到顶部
帅哥哟,离线,有人找我吗?
Jacksnfeng
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:幼狐 帖子:69 积分:733 威望:0 精华:0 注册:2013/4/6 22:31:00
  发帖心情 Post By:2017/5/25 16:45:00 [显示全部帖子]

以下代码的问题是第三个参数选false就会出错,如果选true就没事,不知何解:
filesys.copydirectory("p:\desktop\Foxtable项目\备份资料\source","p:\desktop\Foxtable项目\备份资料\target",False)

 回到顶部