×

windowstee

关于windowstee的信息

admin admin 发表于2023-04-06 14:22:07 浏览70 评论0

抢沙发发表评论

本文目录一览:

使用windows脚本编写自动压缩文件、删除源文件的脚本?

怎么确定什么才算“过去5天”?根据文件名?按创建日期?按修改日期?

另外需要归档的文件,是否分散在不同的路径,不同的文件夹?

我这里强烈推荐使用 robocopy 把需要备份的文件拷贝出来,然后再人工执行压缩,亦或者可以使用计划任务执行压缩任务

robocopy "C:\Log" "R:\RoboCopy\log" /MOV /V /MinaGE:5 /R:10 /W:30 /if *.log

/MOT:分钟 可以设定监视器,定时执行移动文件操作

/MOT:m :: 监视源;如果更改,在 m 分钟时间内再次运行。

详细的参数可以参见下面的命令

-------------------------------------------------------------------------------

ROBOCOPY     ::     Windows 的可靠文件复制

-------------------------------------------------------------------------------

开始时间: Mon Dec 06 08:51:32 2021

用法 :: ROBOCOPY source destination [file [file]...] [options]

源 :: 源目录(驱动器:\路径或\\服务器\共享\路径)。

目标 :: 目标目录(驱动器:\路径或\\服务器\共享\路径)。

文件 :: 要复制的文件(名称/通配符: 默认为 "*.*")。

::

:: 复制选项:

::

/S :: 复制子目录,但不复制空的子目录。

/E :: 复制子目录,包括空的子目录。

/LEV:n :: 仅复制源目录树的前 n 层。

/Z :: 在可重新启动模式下复制文件。

/B :: 在备份模式下复制文件。

/ZB :: 使用可重新启动模式;如果拒绝访问,请使用备份模式。

/EFSRAW :: 在 EFS RAW 模式下复制所有加密的文件。

/COPY:复制标记:: 要复制的文件内容(默认为 /COPY:DAT)。

(复制标记: D=数据,A=属性,T=时间戳)。

(S=安全=NTFS ACL,O=所有者信息,U=审核信息)。

/DCOPY:T :: 复制目录时间戳。

/SEC :: 复制具有安全性的文件(等同于 /COPY:DATS)。

/COPYALL :: 复制所有文件信息(等同于 /COPY:DATSOU)。

/NOCOPY :: 不复制任何文件信息(与 /PURGE 一起使用生效)。

/SECFIX :: 修复所有文件的文件安全性,即使是跳过的文件。

/TIMFIX :: 修复所有文件的文件时间,即使是跳过的文件。

/PURGE :: 删除源中不再存在的目标文件/目录。

/MIR :: 镜像目录树(等同于 /E 和 /PURGE)。

/MOV :: 移动文件(复制后从源中删除)。

/MOVE :: 移动文件和目录(复制后从源中删除)。

/A+:[RASHCNET] :: 将给定的属性添加到复制文件。

/A-:[RASHCNET] :: 从复制文件中删除给定的属性。

/CREATE :: 仅创建目录树和长度为零的文件。

/FAT :: 仅使用 8.3 FAT 文件名创建目标文件。

/256 :: 关闭超长路径( 256 字符)支持。

/MON:n :: 监视源;发现多于 n 个更改时再次运行。

/MOT:m :: 监视源;如果更改,在 m 分钟时间内再次运行。

/RH:hhmm-hhmm :: 运行小时数 - 可以启动新副本的时间。

/PF :: 以每个文件(而不是每个步骤)为基础检查运行小时数。

/IPG:n :: 程序包间的间距(ms),以释放低速线路上的带宽。

/SL :: 对照目标复制符号链接。

/MT[:n] :: 使用 n 个线程进行多线程复制(默认值为 8)。

n 必须至少为 1,但不得大于 128。

该选项与 /IPG 和 /EFSRAW 选项不兼容。

使用 /LOG 选项重定向输出以便获得最佳性能。

::

:: 文件选择选项:

::

/A :: 仅复制具有存档属性集的文件。

/M :: 仅复制具有存档属性的文件并重置存档属性。

/IA:[RASHCNETO] :: 仅包含具有任意给定属性集的文件。

/XA:[RASHCNETO] :: 排除具有任意给定属性集的文件。

/XF 文件[文件]... :: 排除与给定名称/路径/通配符匹配的文件。

/XD 目录[目录]... :: 排除与给定名称/路径匹配的目录。

/XC :: 排除已更改的文件。

/XN :: 排除较新的文件。

/XO :: 排除较旧的文件。

/XX :: 排除多余的文件和目录。

/XL :: 排除孤立的文件和目录。

/IS :: 包含相同文件。

/IT :: 包含已调整的文件。

/MAX:n :: 最大的文件大小 - 排除大于 n 字节的文件。

/MIN:n :: 最小的文件大小 - 排除小于 n 字节的文件。

/MAXAGE:n :: 最长的文件存在时间 - 排除早于 n 天/日期的文件。

/MINAGE:n :: 最短的文件存在时间 - 排除晚于 n 天/日期的文件。

/MAXLAD:n :: 最大的最后访问日期 - 排除自 n 以来未使用的文件。

/MINLAD:n :: 最小的最后访问日期 - 排除自 n 以来使用的文件。

(If n 1900 then n = n days, else n = YYYYMMDD date)。

/XJ :: 排除接合点。(默认情况下通常包括)。

/FFT :: 假设 FAT 文件时间(2 秒粒度)。

/DST :: 弥补 1 小时的 DST 时间差。

/XJD :: 排除目录的接合点。

/XJF :: 排除文件的接合点。

::

:: 重试选项:

::

/R:n :: 失败副本的重试次数: 默认为 1 百万。

/W:n :: 两次重试间的等待时间: 默认为 30 秒。

/REG :: 将注册表中的 /R:n 和 /W:n 保存为默认设置。

/TBD :: 等待定义共享名称(重试错误 67)。

::

:: 日志记录选项:

::

/L :: 仅列出 - 不复制、添加时间戳或删除任何文件。

/X :: 报告所有多余的文件,而不只是选中的文件。

/V :: 生成详细输出,同时显示跳过的文件。

/TS :: 在输出中包含源文件的时间戳。

/FP :: 在输出中包含文件的完整路径名称。

/BYTES :: 以字节打印大小。

/NS :: 无大小 - 不记录文件大小。

/NC :: 无类别 - 不记录文件类别。

/NFL :: 无文件列表 - 不记录文件名。

/NDL :: 无目录列表 - 不记录目录名称。

/NP :: 无进度 - 不显示已复制的百分比。

/ETA :: 显示复制文件的预期到达时间。

/LOG:文件 :: 将状态输出到日志文件(覆盖现有日志)。

/LOG+:文件 :: 将状态输出到日志文件(附加到现有日志中)。

/UNILOG:文件 :: 以 UNICODE 方式将状态输出到日志文件(覆盖现有日志)。

/UNILOG+:文件 :: 以 UNICODE 方式将状态输出到日志文件(附加到现有日志中)。

/TEE :: 输出到控制台窗口和日志文件。

/NJH :: 没有作业标头。

/NJS :: 没有作业摘要。

/UNICODE :: 以 UNICODE 方式输出状态。

::

:: 作业选项 :

::

/JOB:作业名称 :: 从命名的作业文件中提取参数。

/SAVE:作业名称 :: 将参数保存到命名的作业文件

/QUIT :: 处理命令行后退出(以查看参数)。

/NOSD :: 未指定源目录。

/NODD :: 未指定目标目录。

/IF :: 包含以下文件。

Windows 批处理脚本指南: 日志

我在脚本中使用基本日志记录工具,来捕获脚本执行期间或者执行之后的故障信息。使用基本日志记录来检测脚本在运行时正在做什么,以及为什么它这么做。我记得有一个网络操作中心试图解决一个遗留批处理的问题,在这个过程中,系统管理员通常必须尝试读取一个控制台窗口的行,因为它们是滴流而过。当批处理机使用拨号调制解调器连接到远程资源时,在很长一段时间里这种技术工作得很好。然而,宽带的出现意味着批脚本的执行速度超过了任何人能够读取的速度。简单的日志文件将使这些系统管理员的故障排除工作更加容易。-windowstee

在[Part 7 – 函数]({% post_url 2018-01-22-windows-batch-functions %})中,示范了 tee 的简单版实现

这个 tee 函数将Console中的输出同时写入了一个日志文件。在这里,重用了相同的日志文件路径,保存在用户 %TEMP% 文件夹中。如果需要为每个执行保留日志,可以通过 %DATE% 或者 %TIME% 来创建一个唯一的日志文件。-windowstee

在消息的内容前加上一个前缀,例如 script: some message 。这个技巧可以在出错的情况下,快速发现是在哪个地方输出的异常消息。

显示非交互式脚本的各种运行时条件,比如在构建服务器上运行的一些东西,然后重定向到构建日志。遗憾的是,我还不知道有什么DOS技巧(但是)可以区分非交互式会话和交互式会话。 C# 和.Net有个 System.Environment.UserInteractive 属性可以检测这种情况。Unix有一些带有tty文件描述符的技巧。你可能需要监测一个自定义的环境变量来破解实现,比如 %MYSCRIPT_DEBUG% 默认值是false。-windowstee

Windows批处理中,怎样把DOS显示的内容,同时写入到一个log文件中,(重定向不行,它导致屏幕不显示了)

这个你用管道就行了 例如查看IP,你数据ipconfig D:\ip.log 这样你的命令就都在ip.log里了

windows下dos中的命令如何重定向到文件中,要保留dos中的信息

最保险的执行一次,用type 显示出来,单浪费时间

ECHO "1324R43" 1 1.LOG 21

type 1.log

以下会出其他问题,自己试下:

应该用**.cmd 1kk.log 12,而且要保存为批处理或cmd

net stop myservices 1result 12,把它保存为1.bat,

执行call 1.bat就可以了,命令显示,log也保存了。

其他几种方法都行,具体自己试下哪种好:

第一种执行两次,浪费时间

ECHO "1324R43"

ECHO "1324R43" 1.LOG

第二种使用通道显示

ECHO "1324R43" 1.LOG | TYPE 1.LOG

第三种通道win7自带tee工具,在命令行执行

ECHO "1324R43" 1.LOG | TEE 1.LOG

tee.exe 为WIN7自带工具,如果没有就需要下载工具,我现在找类似TEE的UEFI的工具!