一篇文章带你读懂批量处理命令

网友投稿 800 2023-04-03

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

一篇文章带你读懂批量处理命令

批处理,顾名思义,批量处理,它可以将复杂的事情变得简单,最早出现在dos操作系统中,也就是我们经常说的cmd黑窗口,这在早期没有gui界面的时候用的是最多的,而且命令比较丰富,虽然现在有很多功能都被封装到了软件中,但是你会发现在dos中执行操作会更快,哪怕会比较麻烦,如果你无法忍受慢节奏。

下面就基本命令咱们先看看吧,首先打开cmd窗口:

下面我们来看看吧:

打开后可以看到这幅画面,我们可以对他进行一些操作,让他看起来 炫酷一点。

我们先看看怎样操作, 打开属性对话框:

最后我们就得到了这样一个窗口,比以前的是不是要炫酷一点了,哈哈哈哈。

那么dos 里面到底有哪些命令呢?下面我们来看看:

这样就获取到了一部分dos操作系统的命令,也是可以进行批量处理的命令,所以我们形象的称之为批处理脚本。那么这些命令都是怎样使用的了。

一、显示,暂停,清除,注释

1.echo 输出信息

2.pause 暂停

不信,你可以看看这个:

3.cls 清除

清除之后他是没有任何显示的,清除即清空前面的所有内容。

4.rem 注释

另外 :: 也可以起到 rem 的注释作用, 而且更简洁有效。

二、文件目录操作

1. cd 切换目录

2. md 创建文件夹

3. ren重命名

4. move移动文件(夹)

5. del 删除文件

6. copy xcopy 复制文件

很多人觉得这两个用法一样,其实不一样的,当你复制超大型文件时,我想每个人基本都会遇到复制缓慢的尴尬,如果你善用dos命令,可以让你把效率提高至少十倍。copy本身比系统的复制要快,但xcopy更快。

7.dir 列举文件名

可以打印出当前目录所有文件(夹)名

8. 文件属性

三、网络命令

1.net 显示设置网络用户组账号

此命令的语法是:  NET     [ ACCOUNTS | COMPUTER | CONFIG | CONTINUE | FILE | GROUP | HELP |       HELPMSG | LOCALGROUP | PAUSE | SESSION | SHARE | START |       STATISTICS | STOP | TIME | USE | USER | VIEW ]

2.netstat 显示协议统计和当前 TCP/IP 网络连接

NETSTAT [-a] [-b] [-e] [-f] [-n] [-o] [-p proto] [-r] [-s] [-t] [interval]    -a            显示所有连接和侦听端口。   -b            显示在创建每个连接或侦听端口时涉及的可执行程序。                 在某些情况下,已知可执行程序承载多个独立的                 组件,这些情况下,显示创建连接或侦听端口时涉                 及的组件序列。此情况下,可执行程序的名称                 位于底部[]中,它调用的组件位于顶部,直至达                 到 TCP/IP。注意,此选项可能很耗时,并且在您没有                 足够权限时可能失败。   -e            显示以太网统计。此选项可以与 -s 选项结合使用。   -f            显示外部地址的完全限定域名(FQDN)。   -n            以数字形式显示地址和端口号。   -o            显示拥有的与每个连接关联的进程 ID。   -p proto      显示 proto 指定的协议的连接;proto 可以是下列任                 何一个: TCP、UDP、TCPv6 或 UDPv6。如果与 -s 选                 项一起用来显示每个协议的统计,proto 可以是下列任                 何一个: IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP                 或 UDPv6。   -r            显示路由表。   -s            显示每个协议的统计。默认情况下,显示                 IP、IPv6、ICMP、ICMPv6、TCP、TCPv6、UDP 和 UDPv6                 的统计;-p 选项可用于指定默认的子网。   -t            显示当前连接卸载状态。   interval      重新显示选定的统计,各个显示间暂停的间隔秒数。                 按 CTRL+C 停止重新显示统计。如果省略,则 netstat                 将打印当前的配置信息一次。

3.ping 测试IP连接

用法: ping [-t] [-a] [-n count] [-l size] [-f] [-i TTL] [-v TOS]            [-r count] [-s count] [[-j host-list] | [-k host-list]]            [-w timeout] [-R] [-S srcaddr] [-4] [-6] target_name  选项:     -t             Ping 指定的主机,直到停止。                    若要查看统计信息并继续操作 - 请键入 Control-Break;                    若要停止 - 请键入 Control-C。     -a             将地址解析成主机名。     -n count       要发送的回显请求数。     -l size        发送缓冲区大小。     -f             在数据包中设置“不分段”标志(仅适用于 IPv4)。     -i TTL         生存时间。     -v TOS         服务类型(仅适用于 IPv4。该设置已不赞成使用,且                    对 IP 标头中的服务字段类型没有任何影响)。     -r count       记录计数跃点的路由(仅适用于 IPv4)。     -s count       计数跃点的时间戳(仅适用于 IPv4)。     -j host-list   与主机列表一起的松散源路由(仅适用于 IPv4)。     -k host-list   与主机列表一起的严格源路由(仅适用于 IPv4)。     -w timeout     等待每次回复的超时时间(毫秒)。     -R             同样使用路由标头测试反向路由(仅适用于 IPv6)。     -S srcaddr     要使用的源地址。     -4             强制使用 IPv4。     -6             强制使用 IPv6。

4.ipconfig 查看本机网络配置

5.arp 地址转换协议

ARP -s inet_addr eth_addr [if_addr] ARP -d inet_addr [if_addr] ARP -a [inet_addr] [-N if_addr] [-v]    -a            通过询问当前协议数据,显示当前 ARP 项。                 如果指定 inet_addr,则只显示指定计算机                 的 IP 地址和物理地址。如果不止一个网络                 接口使用 ARP,则显示每个 ARP 表的项。   -g            与 -a 相同。   -v            在详细模式下显示当前 ARP 项。所有无效项                 和环回接口上的项都将显示。   inet_addr     指定 Internet 地址。   -N if_addr    显示 if_addr 指定的网络接口的 ARP 项。   -d            删除 inet_addr 指定的主机。inet_addr 可                 以是通配符 *,以删除所有主机。   -s            添加主机并且将 Internet 地址 inet_addr                 与物理地址 eth_addr 相关联。物理地址是用                 连字符分隔的 6 个十六进制字节。该项是永久的。   eth_addr      指定物理地址。   if_addr       如果存在,此项指定地址转换表应修改的接口                 的 Internet 地址。如果不存在,则使用第一                 个适用的接口。 示例:   > arp -s 157.55.85.212   00-aa-00-62-c6-09.... 添加静态项。   > arp -a                                  .... 显示 ARP 表。

6.route 网络路由表

7.tracert路由跟踪

用法: tracert [-d] [-h maximum_hops] [-j host-list] [-w timeout]                [-R] [-S srcaddr] [-4] [-6] target_name  选项:     -d                 不将地址解析成主机名。     -h maximum_hops    搜索目标的最大跃点数。     -j host-list       与主机列表一起的松散源路由(仅适用于 IPv4)。     -w timeout         等待每个回复的超时时间(以毫秒为单位)。     -R                 跟踪往返行程路径(仅适用于 IPv6)。     -S srcaddr         要使用的源地址(仅适用于 IPv6)。     -4                 强制使用 IPv4。     -6                 强制使用 IPv6。

四、系统命令

1.taskkill 查杀进程

TASKKILL [/S system [/U username [/P [password]]]]          { [/FI filter] [/PID processid | /IM imagename] } [/T] [/F]  描述:     使用该工具按照进程 ID (PID) 或映像名称终止任务。  参数列表:     /S    system           指定要连接的远程系统。      /U    [domain\]user    指定应该在哪个用户上下文执行这个命令。      /P    [password]       为提供的用户上下文指定密码。如果忽略,提示                            输入。      /FI   filter           应用筛选器以选择一组任务。                            允许使用 "*"。例如,映像名称 eq acme*      /PID  processid        指定要终止的进程的 PID。                            使用 TaskList 取得 PID。      /IM   imagename        指定要终止的进程的映像名称。通配符 '*'可用来                            指定所有任务或映像名称。      /T                     终止指定的进程和由它启用的子进程。      /F                     指定强制终止进程。      /?                     显示帮助消息。  筛选器:     筛选器名      有效运算符                有效值     -----------   ---------------           -------------------------     STATUS        eq, ne                    RUNNING |                                             NOT RESPONDING | UNKNOWN     IMAGENAME     eq, ne                    映像名称     PID           eq, ne, gt, lt, ge, le    PID 值     SESSION       eq, ne, gt, lt, ge, le    会话编号。     CPUTIME       eq, ne, gt, lt, ge, le    CPU 时间,格式为                                             hh:mm:ss。                                             hh - 时,                                             mm - 分,ss - 秒     MEMUSAGE      eq, ne, gt, lt, ge, le    内存使用量,单位为 KB     USERNAME      eq, ne                    用户名,格式为 [domain\]user     MODULES       eq, ne                    DLL 名称     SERVICES      eq, ne                    服务名称     WINDOWTITLE   eq, ne                    窗口标题      说明     ----     1) 只有在应用筛选器的情况下,/IM 切换才能使用通配符 '*'。     2) 远程进程总是要强行 (/F) 终止。     3) 当指定远程机器时,不支持 "WINDOWTITLE" 和 "STATUS" 筛选器。  例如:     TASKKILL /IM notepad.exe     TASKKILL /PID 1230 /PID 1241 /PID 1253 /T     TASKKILL /F /IM cmd.exe /T     TASKKILL /F /FI "PID ge 1000" /FI "WINDOWTITLE ne untitle*"     TASKKILL /F /FI "USERNAME eq NT AUTHORITY\SYSTEM" /IM notepad.exe     TASKKILL /S system /U domain\username /FI "USERNAME ne NT*" /IM *     TASKKILL /S system /U username /P password /FI "IMAGENAME eq note*"

2.shutdown 关闭或者重启计算机

3.start 启动命令

讲了这么多基础语句是不是想跃跃欲试嘞嘞,其实批处理中还有很多比较高级的东西,比如说循环判断,set设置,下面一起来看看吧。

1.if语句

if语句大家都知道,基本就是用作判断,比如两个数是否相同,一个变量是否存在。它的用法如下:

大家可以看到,这样就完成了一段非常智障的判断语句,哈哈哈。了解了这个简单的语法后,我们是不是该整点新鲜的东西了,比如说变量啥的,下面请看:

可以看到使用关键字set定义变量就完成了交互操作,赋值。

说完了判断,变量,当然还有循环啦,for 循环相信大家都不陌生,在哪里都有它的身影,dos也不例外。

不过貌似这个for语句的话操作起来在cmd窗口中和在批处理文件中结果不一样哦,具体表现为前者需要在变量前加一个%,后者则是两个%%。for语句里有三个关键字 for 、in、do 三者缺一不可。

怎么样,是不是超级简单。当然,它还有很多有趣的地方,比如你想查看某个目录的所有文件:

这样就打印出了当前桌面目录中所有的txt文件。

好了,今天就讲到这里,更多精彩内容期待你的参与。

上一篇:用Word制表能这么方便?这Word小技巧你用过吗
下一篇:告警分析应用场景(告警规则和策略包含的信息)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~