设为首页 收藏本站
查看: 1005|回复: 0

[经验分享] windows shell 简单学习

[复制链接]

尚未签到

发表于 2018-6-24 10:19:26 | 显示全部楼层 |阅读模式
━━━━━━━━━━━━━━━━━━━━━━━━━━ 1、替换字符串 ━━━━━━━━━━━━━━━━━━━━━━━━━━ 替换字符串,即将某一字符串中的特定字符或字符串替换为给1、替换字符串替换字符串,即将某一字符串中的特定字符或字符串替换为给定的字符串。举例说明其功能:  =========================================  @echo off  set aa=伟大的中国!我为你自豪!  echo 替换前:%  echo 替换后::中国=中华人民共和国%  echo aa = %  set "aa=:中国=中华人民共和国%"  echo aa = %  pause  =========================================  对于上面的例子有一点说明,对比两个echo aa = %可以发现,如果要修改变量aa的内容的话,就需要将修改结果“:中国=中华人民共和国%”赋值给变量aa。上面的字符串截取也有着同样的特点。  ━━━━━━━━━━━━━━━━━━━━━━━━━━
2、截取字符串━━━━━━━━━━━━━━━━━━━━━━━━━━        截取字符串可以说是字符串处理功能中最常用的一个子功能了,能够实现截取字符串中的特定位置的一个或多个字符。举例说明其基本功能:  =========================================  @echo off  set ifo=abcdefghijklmnopqrstuvwxyz0123456789  echo 原字符串(第二行为各字符的序号):  echo %ifo%  echo 123456789012345678901234567890123456  echo 截取前5个字符:  echo %ifo:~0,5%  echo 截取最后5个字符:  echo %ifo:~-5%  echo 截取第一个到倒数第6个字符:  echo %ifo:~0,-5%  echo 从第4个字符开始,截取5个字符:  echo %ifo:~3,5%  echo 从倒数第14个字符开始,截取5个字符:  echo %ifo:~-14,5%  pause  =========================================  当然,上面的例子只是将字符串处理的基本功能展示出来了,还看不出字符串处理具体有什么用处。下面这个例子是对时间进行处理。  =========================================  @echo off  echo 当前时间是:%time% 即 %time:~0,2%点%time:~3,2%分%time:~6,2%秒%time:~9,2%厘秒  pause  =========================================━━━━━━━━━━━━━━━━━━━━━━━━━━3、扩充字符串━━━━━━━━━━━━━━━━━━━━━━━━━━       “扩充”这个词汇来自于微软自己的翻译,意思就是对表示文件路径的字符串进行特殊的处理,具体功能罗列如下:  =========================================  ~I - 删除任何引号("),扩充 %I  %~fI - 将 %I 扩充到一个完全合格的路径名  %~dI - 仅将 %I 扩充到一个驱动器号  %~pI - 仅将 %I 扩充到一个路径  %~nI - 仅将 %I 扩充到一个文件名  %~xI - 仅将 %I 扩充到一个文件扩展名  %~sI - 扩充的路径只含有短名  %~aI - 将 %I 扩充到文件的文件属性  %~tI - 将 %I 扩充到文件的日期/时间  %~zI - 将 %I 扩充到文件的大小  %~$PATH:I - 查找列在路径环境变量的目录,并将 %I 扩充  到找到的第一个完全合格的名称。如果环境变量名  未被定义,或者没有找到文件,此组合键会扩充到  空字符串  可以组合修饰符来得到多重结果:  %~dpI - 仅将 %I 扩充到一个驱动器号和路径  %~nxI - 仅将 %I 扩充到一个文件名和扩展名  %~fsI - 仅将 %I 扩充到一个带有短名的完整路径名  %~dp$PATH:i - 查找列在路径环境变量的目录,并将 %I 扩充  到找到的第一个驱动器号和路径。  %~ftzaI - 将 %I 扩充到类似输出线路的 DIR  =========================================  以上内容引用于for /?帮助信息。其中的I代表变量I,不过需要说明的是,不是所有的变量都能够进行扩充的,有两个条件:1、该字符串代表一个文件路径;2、变量要用%x来表示,x可取a-z A-Z 0-9共62个字符中的任意一个。举例说明:  @echo off  echo 正在运行的这个批处理:  echo 完全路径:%0  echo 去掉引号:%~0  echo 所在分区:%~d0  echo 所处路径:%~p0  echo 文件名:%~n0  echo 扩展名:%~x0  echo 文件属性:%~a0  echo 修改时间:%~t0  echo 文件大小:%~z0  pause  =========================================  其中的%0是批处理里面的参数,代表当前运行的批处理的完全路径。类似的还有%1-%9,分别代表传递来的第1-9个参数。例子如下:  ===============================================  @echo off  set aa=C:\Windows\PPP\a.btx  call :deal aaa % "c c" ddd eee  pause>nul  exit  :deal  echo %%0 = %0  echo %%1 = %1  echo %%2 = %2  echo %%3 = %3  echo %%4 = %4  echo %%5 = %5  ===============================================  其中,变量aa在之前是不可以扩充的,通过call命令并将aa作为参数传递给子函数:deal,将aa变量转换成了变量%1,即符合%x格式,从而可以进行字符串扩充。    至于%x中x取a-z A-Z的形式,可以复习一下for语句,for语句里面的变量就是用%x来表示的,因而可以直接进行扩充。━━━━━━━━━━━━━━━━━━━━━━━━━━4、获取字符串长度━━━━━━━━━━━━━━━━━━━━━━━━━━    通过循环截取字符串来获取,代码如下:     =========================================    @echo off    set mystr=hello world    set str=%mystr%    ::将"号替换成空格    set "str=%str:"= %"    :next    if not "%str%"=="" (        set /a num+=1        set "str=%str:~1%"        goto next    )    echo %mystr%字符串长度为:%num%    pause    =========================================    运行结果:    hello world字符串长度为:11下面是删除当前目录下前面3天的 YYYYMMDD.LOG文件的脚本的例子: @echo offset date1=te%set /a date3=te1:~8,2%set /a date4=te3%-3set /a date5=te3%-4set /a date6=te3%-5set /a date5=te3%-2set Ddate1=te1:~0,4%te1:~5,2%te4%.logset Ddate2=te1:~0,4%te1:~5,2%te5%.logset Ddate3=te1:~0,4%te1:~5,2%te6%.logset path=%~d0%~p0echo %path%ate1% del /Q /F %path%ate1%del /Q /F %path%ate2%del /Q /F %path%ate3%

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-529907-1-1.html 上篇帖子: Nagios监控Linux、Windows的网卡流量 下篇帖子: Windows优化策略及Netcat后门工具
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表