批处理脚本 – 处理

批处理脚本 – 处理


在本章中,我们将讨论批处理脚本中涉及的各种过程。

查看正在运行的进程列表

在批处理脚本中,TASKLIST 命令可用于获取系统中当前正在运行的进程列表。

句法

TASKLIST [/S system [/U username [/P [password]]]] [/M [module] | /SVC | /V] [/FI filter]
[/FO format] [/NH]

S.No. 选项和说明
1.

/S system

指定要连接的远程系统

2.

/U

[domain\]user

指定应在其下执行命令的用户上下文。

3.

/P [password]

指定给定用户上下文的密码。如果省略则提示输入。

4.

/M [module]

列出当前使用给定 exe/dll 名称的所有任务。如果未指定模块名称,则会显示所有加载的模块。

5.

/SVC

显示在每个进程中托管的服务。

6.

/V

显示详细的任务信息。

7.

/FI filter

显示与过滤器指定的给定条件匹配的一组任务。

8.

/FO format

指定输出格式。有效值:“TABLE”、“LIST”、“CSV”。

9.

/NH

指定“列标题”不应显示在输出中。仅对“TABLE”和“CSV”格式有效。

例子

TASKLIST

上面的命令将获取本地系统上运行的所有进程的列表。以下是当上述命令按原样运行时呈现的输出快照。从以下输出中可以看出,您不仅可以获得系统上运行的各种进程,还可以获得每个进程的内存使用情况。

Image Name                    PID       Session Name       Session#     Mem Usage
========================= ========    ================ =========== ============
System Idle Process             0        Services            0              4 K
System                          4        Services            0            272 K
smss.exe                      344        Services            0          1,040 K
csrss.exe                     528        Services            0          3,892 K
csrss.exe                     612        Console             1         41,788 K
wininit.exe                   620        Services            0          3,528 K
winlogon.exe                  648        Console             1          5,884 K
services.exe                  712        Services            0          6,224 K
lsass.exe                     720        Services            0          9,712 K
svchost.exe                   788        Services            0         10,048 K
svchost.exe                   832        Services            0          7,696 K
dwm.exe                       916        Console             1        117,440 K
nvvsvc.exe                    932        Services            0          6,692 K
nvxdsync.exe                  968        Console             1         16,328 K
nvvsvc.exe                    976        Console             1         12,756 K
svchost.exe                  1012        Services            0         21,648 K
svchost.exe                   236        Services            0         33,864 K
svchost.exe                   480        Services            0         11,152 K
svchost.exe                  1028        Services            0         11,104 K
svchost.exe                  1048        Services            0         16,108 K
wlanext.exe                  1220        Services            0         12,560 K
conhost.exe                  1228        Services            0          2,588 K
svchost.exe                  1276        Services            0         13,888 K
svchost.exe                  1420        Services            0         13,488 K
spoolsv.exe                  1556        Services            0          9,340 K

tasklist > process.txt

上述命令获取 tasklist 显示的输出并将其保存到 process.txt 文件中。

tasklist /fi "memusage gt 40000"

上面的命令只会获取那些内存大于 40MB 的进程。以下是可以呈现的示例输出。

Image Name                    PID      Session Name     Session#     Mem Usage
=========================   ======== ================ =========== ============
dwm.exe                        916     Console             1        127,912 K
explorer.exe                  2904     Console             1        125,868 K
ServerManager.exe             1836     Console             1         59,796 K
WINWORD.EXE                   2456     Console             1        144,504 K
chrome.exe                    4892     Console             1        123,232 K
chrome.exe                    4976     Console             1         69,412 K
chrome.exe                    1724     Console             1         76,416 K
chrome.exe                    3992     Console             1         56,156 K
chrome.exe                    1168     Console             1        233,628 K
chrome.exe                     816     Console             1         66,808 K

杀死特定进程

允许运行 Microsoft Windows XP Professional、Windows 2003 或更高版本的用户通过进程 ID (PID) 或映像名称从 Windows 命令行终止任务。用于此目的的命令是 TASKILL 命令。

句法

TASKKILL [/S system [/U username [/P [password]]]] { [/FI filter] 
[/PID processid | /IM imagename] } [/T] [/F]

S.No. 选项和说明
1.

/S system

指定要连接的远程系统

2.

/U

[domain\]user

指定应在其下执行命令的用户上下文。

3.

/P [password]

指定给定用户上下文的密码。如果省略则提示输入。

4.

/FI

FilterName

应用过滤器来选择一组任务。允许使用“*”。前任。imagename eq acme* 有关其他信息和示例,请参见下面的过滤器。

5.

/PID

processID

指定要终止的进程的PID。使用 TaskList 获取 PID。

6.

/IM

ImageName

指定要终止的进程的映像名称。通配符“*”可用于指定所有任务或图像名称。

7.

/T

终止指定的进程和由它启动的任何子进程。

8.

/F

指定强制终止进程。

例子

taskkill /f /im notepad.exe

如果打开,上面的命令会终止打开的记事本任务。

taskill /pid 9214

上面的命令会杀死一个进程为 9214 的进程。

开始一个新的过程

DOS 脚本也可以完全启动一个新进程。这是通过使用 START 命令实现的。

句法

START "title" [/D path] [options] "command" [parameters]

其中

  • title – CMD 窗口标题栏的文本(必需。)

  • 路径– 起始目录。

  • command – 要运行的命令、批处理文件或可执行程序。

  • 参数– 传递给命令的参数。

S.No. 选项和说明
1.

/MIN

启动窗口最小化

2.

/MAX

启动窗口最大化。

3.

/LOW

使用 IDLE 优先级。

4.

/NORMAL

使用 NORMAL 优先级。

5.

/ABOVENORMAL

使用 ABOVENORMAL 优先级。

6.

/BELOWNORMAL

使用 BELOWNORMAL 优先级。

7.

/HIGH

使用高优先级。

8.

/REALTIME

使用实时优先级。

例子

START "Test Batch Script" /Min test.bat

上述命令将在新窗口中运行批处理脚本 test.bat。窗口将以最小化模式启动,并且标题为“Test Batch Script”。

START "" "C:\Program Files\Microsoft Office\Winword.exe" "D:\test\TESTA.txt"

上面的命令实际上会在另一个进程中运行 Microsoft Word,然后在 MS Word 中打开文件 TESTA.txt。

觉得文章有用?

点个广告表达一下你的爱意吧 !😁