Windows批处理编程(包含基础DOS命令)-程序员宅基地

技术标签: windows  

目录

一:概述

什么是批处理程序?

2.如何编辑批处理程序?

3.批处理程序可以做什么?

5.最简单的一个批处理程序:

二:基本操作

批处理运算操作

算术运算

重定向运算

多命名运算

管道运算

补充指令:

批处理基本命令

命令格式:

批处理文件参数传递:

注释符拓展:(rem是注释符)

炫酷命令提示符(包括颜色命令和标题命令)

时间日期

启动命令介绍与使用

调用其他bat文件

任务列表查看命令

任务关闭命令

文件夹结构查看命令

关机命令

计划任务命令

批处理环境变量

文件夹或文件相关命令

目录浏览命令(dir)

目录新建与删除命令(mkdir  rmdir)

目录切换命令(chdir)

目录重命名(rename)

目录拷贝命令(copy)

文件删除命令(del)

文件剪切命令(move)

​编辑 

网络相关命令

用户操作命令

用户组操作命令

网络联通性检测命令

网络连接命令

网络路由信息命令

网络适配器命令

ARP信息命令

条件判断结构

If-else

判断文件是否存在

循环结构



一:概述

  1. 什么是批处理程序?

Batch file programming是微软操作系统自带的原生的开发语言,不需要构建任何环境就可以执行的脚本。且Batch file批处理文件使用cmd.exe执行。

2.如何编辑批处理程序?

可以使用记事本。

3.批处理程序可以做什么?

使用一系列内置命令进行自动化操作。

4.批处理文件,可以直接拿记事本写,然后保存,将文件扩展名改为.bat   

5.最简单的一个批处理程序:

@echo off

Echo "hello world" 

Pause

(@ echo off是用来关闭盘符显示的,@符号的意思是不显示它后面的命令语句只显示命令执行的结果!)

(双引号不是必须有的,它在echo输出语句中只是一个普通字符)

(pause保证不会出现闪退的结果,一般情况下可有可无)

6.批处理命令可以分为:内部命令(如ipconfig,calc)和外部命令(打开Java或者Python,就可以进行相关编码),将两者结合就可以实现更强大的功能。


二:基本操作

批处理运算操作

  • 算术运算

进行算数运算可以用命令模式,也可以是文本模式。

命令模式:需要打开cmd ,首先输入  set /a (这几个字符表示要进行算数运算了),然后后面再跟上需要进行算数运算的式子,如下图所示(cmd中不区分大小写)

但是命令模式只能执行一次,执行多次操作需使用文本模式,就是先在文本中编辑,然后将文件改为.bat,运行即可查看结果。在这里,学到了批处理命令中也可以定义变量,如

 @echo off

set /a var=4*8

echo %var%

pause

变量设为了var,要输出的时候,一定要用“%%”包裹住变量。

  • 重定向运算

使用场景:某条命令执行的结果会添加或者移交给我们的下一个执行的命令,或者将输出的结果保存到一个具体的文件中。

重定向运算中常用的四个符号:>  >>  <  <<

箭头所指向的方向代表最终要将数据存储到对应的这个结果位置 。

一个箭头的会覆盖原有的内容,两个不会覆盖之前的内容,代表最佳状态。当然“<”和“>”也可以表示逻辑运算中的大于小于。

Type + 文件名 可用于查看文件中的内容,(一般用于查看.txt文件吧我觉得)必须要在对应的根目录下打开cmd,才能进行对应的操作

 

  • 多命名运算

主要符号: && 和 ||(其实就是学过的与和或)

&&(||)一般用法:命令1 &&(||) 命令2

&&:其中一个命令错误,则剩下的那个命令就不会执行了。当都正确时,两个命令都要执行。

||: 其中一个错误了,会有报错提示,但剩下那个正确的依然会执行。当都正确时,两个命令只执行第一个。

  • 管道运算

只有一个 | 符号

用法:  A | B   A命令输出的内容作为B命令的输入,如下图的    dir | find "txt"

补充指令:

net user 出现有关电脑账号的信息

netstat -an 内置命令,将网络连接以数字形式完全显示出来。

在对应文件根目录下打开cmd,然后直接输入文件名,cmd就会帮我们打开这个文件。

需要注意的是:可以打开文件,比如.txt .jpg .php,但是不能打开文件夹!

cmd中cd .. 可以返回上一级

 

批处理基本命令

  • 命令格式:

命令--子命令--参数--操作(--选项,比如激活选项)

如: net user test test /add 这一命令,net就是命令,user就是子命令。

每一条命令参数和使用方式是不同的,但是他的格式是类似的,可以使用帮助信息,也就是 /? 或者 /help

  • 批处理文件参数传递:

就是.bat文件接受参数使用,可以使用 %num (也就是%加数字)来进行接收。

 

当然也可以 3.bat 内部是 net user %1 %2 /add

然后cmd中指令 3.bat admin 123456 ,就能把参数传递到.bat文件中,然后执行了。

  • 注释符拓展:(rem是注释符)

rem + comment(也就是需要注释的内容),如果忘记什么了,就可以在cmd中使用type+文件名 来查看文件中的具体注释内容。

 

可以看到,内容是一样的。

炫酷命令提示符(包括颜色命令和标题命令)

Color + 两位十六进制数 即可改变颜色,如color 0a 就是黑色背景,绿色前景

美中不足的地方在于它只能设置单次,当我们关闭之后,再打开,又会恢复成默认的黑白色。

标题命令: title+其他字符 就可以改变上面的title

  1. 时间日期

关键字:

Date可查看年月日

Time可查看时分秒

ctrl+c可以结束查询,或者直接查询后加一个 /T

  1. 启动命令介绍与使用

关键字:start

  • Start:可新建一个cmd窗口
  • Start "bt" :可以新建一个title为bt的窗口
  • Start+文件名 :就是打开文件,会新建一个窗口
  • B :启动应用程序,但不会创建新窗口了
  • 其他的可以在 start /?或者/help处学习
  1. 调用其他bat文件

关键字: call

Call 2.bat  这叫做次文件,次文件不能传参,也就是如果 2.bat里的文件是: echo %1 ,那么在 cmd中无法进行 call 2.bat ex的操作,只能是 2.bat 中是固定的已经写好的文件如 net user等,跟在主文件的后面,一起执行。

  1. 任务列表查看命令

关键字:tasklist

当然也可以跟上 /?或 /help来查看对应的帮助指令,该工具显示在本地或远程机器上当前运行的进程列表。即:

查看远程系统任务列表一般格式:

tasklist /S 127.0.0.1(IP远程系统的IP地址,此处为例) -u账号 -p 密码

(进行远程查看要匹配对应的身份信息,账号密码)

就可以查看到了

/help中还有一些其他的筛选器,以 /FI做演示,输入命令:

Tasklist  /FI  “status  eq  running” //

Tasklist  /FI  “PID  eq  26448”    //

Tasklist  /FI  “imagename   eq  cmd.exe”  //

默认输出格式为 form形式

也可以修改为其他格式,在后面加一个 /FO + 有效值

比如两种不同的输出格式:

此外,cmd中的*表示个数匹配字符(表示一个任意的字符),比如*.txt ,既可以匹配到a.txt,也可以匹配到 b.txt ,前提是你文件夹中有这两个.txt文件。

当然,也可以查看 /?中的examples中的案例

常用的有效运算符:

Eq  等于

Ne  不等于

Gt  大于

Lt  小于

Ge 大于等于

Le 小于等于

  1. 任务关闭命令

关键字:taskkill

既可以终止本地进程,又可以终止远程系统的进程。

当然在这个命令中,仍然可以 /help寻求帮助, 仍然存在筛选器。

以关闭记事本(notepad)为例进行演示:

  • 通过 /IM文件名称进行关闭
  • 通过pid进行关闭

首先找到被打开的记事本的pid(可以在任务管理器--详细信息--pid处查看,也可以在cmd中的tasklist查看)

如果在这个基础上加上 /T ,则它的子项(子进程)也会被终止。

强制关闭cmd,直接 taskkill /im cmd.exe是行不通的

正确做法: taskkill /f /im cmd.exe(/t)

关闭在远程系统任务命令和查看时一样,都是要先

Taskkill /s IP地址 -u 账号 -p密码 (后面加上 /fi “pid  eq  一个数”)

  1. 文件夹结构查看命令

关键字:tree

作用:将我们当前所在路径或者是指定路径的文件夹中的内容,以一种树形的结构来展示

Tree + /f 则会显示的更加详细,如

 

  1. 关机命令

关键字:shutdown

远程关机:/i可以打开CUI可视化界面,添加对应的IP地址

下面的注释框中输入字符后,会被弹出到被执行指定命令的计算机的屏幕上。

此外,要关闭本地的计算机,还可以通过 shutdown /p /h 等命令来进行相应的操作。

  1. 计划任务命令

关键字:at

at 时间(如:22:00)/every:M,T,W  C:\abc.exe

在某一时间点/每天或是星期几/执行.exe文件或者其他的如 .txt  .bat 文件

演示:at 11:07 "notepad.exe"

意思就是在11:07的时候打开notepad,但是不会显示在桌面,而是隐藏起来了,在任务管理器中可以看到,在网安渗透方面有着一些作用,但是在Win10的时候,AT命令就已经被弃用了。

  1. 批处理环境变量

设置环境变量,可以替代一些复杂的路径,可以通过set命令查看当前系统的环境变量。(这是系统设置好的)

echo  %“环境变量”%  输出后就可以看到变量对应的值。

  1. 文件夹或文件相关命令

  • 目录浏览命令(dir)

Dir=directory用来查看当前目录里面又那些信息,演示:

注意:它很有可能不是全部的目录,因为Windows系统默认情况下不会显示隐藏文件或者是目录,需要使用对应的参数才可以查看到它所有的信息。

此外,在/help中还有更多的操作方法(如 dir /ar),自行观看。

  • 目录新建与删除命令(mkdir  rmdir)

新建mkdir------md(缩写)

删除Rmdir------rd(缩写)

直接在对应的子目录下输入命令

(以C:\Users\lenovo\Desktop\DOS命令>为例   )

Mkdir aaa

可以看到在“DOS命令”文件夹中,立马就生成了一个名为aaa的文件夹。

Rmdir aaa就可以将aaa文件夹删除。

但如果aaa目录不为空,但是还想要删除它,就得用 /S

不同的是,删除操作是有参数可以传递的

演示:

 

  • 目录切换命令(chdir)

chdir------cd(缩写)

在新建一个文件之后,里面只有两个内容

.和..   .表示当前目录   ..表示上一级目录

最常用的一个命令:cd .. 表示返回上一级目录

  • 目录重命名(rename)

rename------ren(缩写)

演示: ren test test1

将test改名为test1

  • 目录拷贝命令(copy)

在DOS命令根目录下,先新建两个<dir>test1/2,然后进入test1目录,echo 111>q.txt  就完成了q.txt文档的制作,顺便存放了111这个数据。

copy test1 test2 将test1中的内容复制到test2中。

补充:

  1. start既可以用来打开文件,也可以用来打开文件夹,但前提都是要在最近的根目录下打开 也就是   C:##\##\爸爸> start 儿子(儿子文件)
  2. Tree可以看到根目录下的子目录,tree /f 不仅可以看到子目录,还能看到根目录下的文件。
  3. Dir和tree /f 差不多,既可以看到文件夹,也可以看到文件,但是某方面没有tree /f 详细
  • 文件删除命令(del)

演示:删除DOS命令下的rrr.txt文件

注意是del,而不是delete噢

如果要删除一个文件夹里的很多(.txt文件)内容,则可以使用通配符*

如 del + 路径 + \*.txt

  • 文件剪切命令(move)

作用:移动文件并且重命名文件和目录

重命名:

移动文件:得在文件前加绝对路径(如下图所示,将a.txt移动到b.txt)

 

  1. 网络相关命令

  • 用户操作命令

关键字:net user

作用:既可以新建用户账户,又可以删除用户账户

 

 

Net user+账户名 可查看具体的账户信息

  • 用户组操作命令

关键字:net localgroup

作用:修改计算机上的本地组。

假设有一个用户名“admin”,它的本地组成员只有 Users

那么我们可以通过 net localgroup  administrators  admin /add

将administrators变为用户admin的本地组成员

将 /add 改为 /delete 就可以删除了

  • 网络联通性检测命令

关键字:ping

最简单的用法 ping + target name也就是目标IP地址,这样就可以执行对应的ping操作,它会发送一个icmp的数据包到目标去,目标如果存活,就会给他一个响应,由此可以判断对应的主机是否存活或者已开机,以及判断网络是否可以正常联通。例如:

没有丢包现象,说明咱们与目标的连通性特别好。

Ping 127.0.0.1 用这句命令来检测本地 TCP/IP协议是否正常,也就是网卡是否正常。

通过 ping -l 发送很大的缓冲区到目标计算机。

如果想知道本地的最大缓冲区,可以这样搞:(把ip地址换为127.0.0.1)

如果是想要发送很多的ping命令,就可以使用参数 -t

Ping -l 65500 -t 192.168.0.1

此时会显示请求超时,因为这个192.168.0.1机器可能已经宕机了,无法进行正常的访问,也可能是启动了防火墙WDF。

这就是 ping of death 的一条命令(死亡之ping),就是使对方IP内存溢出,使系统崩溃。

  • 网络连接命令

关键字:telnet

之前是进行网络主机的管理,但是现在它在传输数据的过程中不加密,所以它会逐渐的被一些加密的传输协议所替代。但是它仍然可以进行远程主机的连接。

Telnet可以连接对应的任意的端口,所以telnet可以进行端口连接的测试以及连接具体主机的一种测试。

  • 网络路由信息命令

关键字:tracert

可以探测本地主机与远程主机究竟经过多少个网络设备,多少个IP地址才能正常连接。

Tracert + IP地址/域名

从本机到百度要经过13个点.

  • 网络适配器命令

关键字:ipconfig

ipconfig  //  ipconfig/all

释放IP地址:ipconfig /release

重新获得IP地址: ipconfig /renew

  • ARP信息命令

可以防御ARP欺骗,我也没听懂……

  1. 条件判断结构

  • If-else

输出结果为 OK

>nul的作用是不显示“请按任意键继续”

  • 判断文件是否存在

关键字:exist

判断文件是否在某个路径中存在(判断 1.bat是否在这个路径下)

 

 

  1. 循环结构

对一件事情重复执行(遍历目录)

For /d in (路径/*) do 具体操作

/d:只会遍历文件夹,不会遍历文件,遍历完成就可以 do 一些具体操作 。Emmm,完结了。

欢迎批评指正》》》

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lmei1228/article/details/131366084

智能推荐

HTML5 Web SQL 数据库_方式准则的定义-程序员宅基地

文章浏览阅读1k次。1、HTML5 Web SQL 数据库 Web SQL 数据库 API 并不是 HTML5 规范的一部分,但是它是一个独立的规范,引入了一组使用 SQL 操作客户端数据库的 APIs。如果你是一个 Web 后端程序员,应该很容易理解 SQL 的操作。Web SQL 数据库可以在最新版的 Safari, Chrome 和 Opera 浏览器中工作。2、核心方法 以下是规范中定义的三个_方式准则的定义

spring Boot 中使用线程池异步执行多个定时任务_springboot启动后自动开启多个线程程序-程序员宅基地

文章浏览阅读4.1k次,点赞2次,收藏6次。spring Boot 中使用线程池异步执行多个定时任务在启动类中添加注解@EnableScheduling配置自定义线程池在启动类中添加注解@EnableScheduling第一步添加注解,这样才会使定时任务启动配置自定义线程池@Configurationpublic class ScheduleConfiguration implements SchedulingConfigurer..._springboot启动后自动开启多个线程程序

Maven编译打包项目 mvn clean install报错ERROR_mvn clean install有errors-程序员宅基地

文章浏览阅读1.1k次。在项目的target文件夹下把之前"mvn clean package"生成的压缩包(我的是jar包)删掉重新执行"mvn clean package"再执行"mvn clean install"即可_mvn clean install有errors

navacate连接不上mysql_navicat连接mysql失败怎么办-程序员宅基地

文章浏览阅读974次。Navicat连接mysql数据库时,不断报1405错误,下面是针对这个的解决办法:MySQL服务器正在运行,停止它。如果是作为Windows服务运行的服务器,进入计算机管理--->服务和应用程序------>服务。如果服务器不是作为服务而运行的,可能需要使用任务管理器来强制停止它。创建1个文本文件(此处命名为mysql-init.txt),并将下述命令置于单一行中:SET PASSW..._nvarchar链接不上数据库

Python的requests参数及方法_python requests 参数-程序员宅基地

文章浏览阅读2.2k次。Python的requests模块是一个常用的HTTP库,用于发送HTTP请求和处理响应。_python requests 参数

近5年典型的的APT攻击事件_2010谷歌网络被极光黑客攻击-程序员宅基地

文章浏览阅读2.7w次,点赞7次,收藏50次。APT攻击APT攻击是近几年来出现的一种高级攻击,具有难检测、持续时间长和攻击目标明确等特征。本文中,整理了近年来比较典型的几个APT攻击,并其攻击过程做了分析(为了加深自己对APT攻击的理解和学习)Google极光攻击2010年的Google Aurora(极光)攻击是一个十分著名的APT攻击。Google的一名雇员点击即时消息中的一条恶意链接,引发了一系列事件导致这个搜_2010谷歌网络被极光黑客攻击

随便推点

微信小程序api视频课程-定时器-setTimeout的使用_微信小程序 settimeout 向上层传值-程序员宅基地

文章浏览阅读1.1k次。JS代码 /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { setTimeout( function(){ wx.showToast({ title: '黄菊华老师', }) },2000 ) },说明该代码只执行一次..._微信小程序 settimeout 向上层传值

uploadify2.1.4如何能使按钮显示中文-程序员宅基地

文章浏览阅读48次。uploadify2.1.4如何能使按钮显示中文博客分类:uploadify网上关于这段话的搜索恐怕是太多了。方法多也试过了不知怎么,反正不行。最终自己想办法给解决了。当然首先还是要有fla源码。直接去管网就可以下载。[url]http://www.uploadify.com/wp-content/uploads/uploadify-v2.1.4...

戴尔服务器安装VMware ESXI6.7.0教程(U盘安装)_vmware-vcsa-all-6.7.0-8169922.iso-程序员宅基地

文章浏览阅读9.6k次,点赞5次,收藏36次。戴尔服务器安装VMware ESXI6.7.0教程(U盘安装)一、前期准备1、下载镜像下载esxi6.7镜像:VMware-VMvisor-Installer-6.7.0-8169922.x86_64.iso这里推荐到戴尔官网下载,Baidu搜索“戴尔驱动下载”,选择进入官网,根据提示输入服务器型号搜索适用于该型号服务器的所有驱动下一步选择具体类型的驱动选择一项下载即可待下载完成后打开软碟通(UItraISO),在“文件”选项中打开刚才下载好的镜像文件然后选择启动_vmware-vcsa-all-6.7.0-8169922.iso

百度语音技术永久免费的语音自动转字幕介绍 -程序员宅基地

文章浏览阅读2k次。百度语音技术永久免费的语音自动转字幕介绍基于百度语音技术,识别率97%无时长限制,无文件大小限制永久免费,简单,易用,速度快支持中文,英文,粤语永久免费的语音转字幕网站: http://thinktothings.com视频介绍 https://www.bilibili.com/video/av42750807 ...

Dyninst学习笔记-程序员宅基地

文章浏览阅读7.6k次,点赞2次,收藏9次。Instrumentation是一种直接修改程序二进制文件的方法。其可以用于程序的调试,优化,安全等等。对这个词一般的翻译是“插桩”,但这更多使用于软件测试领域。【找一些相关的例子】Dyninst可以动态或静态的修改程序的二进制代码。动态修改是在目标进程运行时插入代码(dynamic binary instrumentation)。静态修改则是直接向二进制文件插入代码(static b_dyninst

在服务器上部署asp网站,部署asp网站到云服务器-程序员宅基地

文章浏览阅读2.9k次。部署asp网站到云服务器 内容精选换一换通常情况下,需要结合客户的实际业务环境和具体需求进行业务改造评估,建议您进行服务咨询。这里仅描述一些通用的策略供您参考,主要分如下几方面进行考虑:业务迁移不管您的业务是否已经上线华为云,业务迁移的策略是一致的。建议您将时延敏感型,有快速批量就近部署需求的业务迁移至IEC;保留数据量大,且需要长期稳定运行的业务在中心云上。迁移方法请参见如何计算隔离独享计算资源..._nas asp网站