bash常用方法总结.docxVIP

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
bash常用方法总结

系统管理中 bash shell 脚本常用方法总结(转) 在日常系统管理工作中,需要编写脚本来完成特定的功能,编写shell脚本是一个基本功了! 在编写的过程中,掌握一些常用的技巧和语法就可以完成大部分功能了,也就是2/8原则. 1. 单引号和双引号的区别 单引号与双引号的最大不同在于双引号仍然可以引用变量的内容,但单引号内仅是普通字符 ,不会作变量的引用,直接输出字符窜。请看如下例子: [root@linux ~]# name=HaHa [root@linux ~]# echo $name HaHa [root@linux ~]# myname=$name is wow [root@linux ~]# echo $myname HaHa is wow [root@linux ~]# myname=$name is wow [root@linux ~]# echo $myname $name is wow 从上面例子可以看出,使用了单引号的时候,那么$name只是普通字符,直接输出而已! 2. 逐行读取文件 使用for循环来读取文件 for line in `cat file.txt` do echo $line done 注意:由于使用for来读入文件里的行时,会自动把空格和换行符作为一样分隔符,如果行里有空格的时候,输出的结果会很乱,所以只适用于行连续不能有空格或者换行符的文件 使用while循环读取文件 cat file.txt |while read line do echo $line done 或者: while read line do echo $line done file.txt 注意:由于使用while来读入文件里的行时,会整行读入,不会关注行的内容(空格..),所以比for读文件有更好的适用性,推荐使用while循环读取文件 3. bash shell 脚本中常用隐含变量 $0当前执行的脚本或者命令名称$1-$9代表参数的位置. 举例 $1 代表第一个参数.$#脚本调用的参数的个数$@所有参数的内容$*所有参数的内容$$当前运行脚本的进程号$?命令执行后返回的状态$!后台运行的最后一个进程号注意: $? 用于检查上一个命令执行是否正确(在Linux中,命令退出状态为0表示该命令正确执行,任何非0值表示命令出错) $$ 变量最常见的用途是用做暂存文件的名字以保证暂存文件不会重复。 $* 和 $@ 如果输出是一样的,但是在使用for循环,在使用 双引号()引用时 $* 会输出成一个元素 而 $@ 会按照每个参数是一个元素方式输出 请看测试例子 #cat test.sh #!/bin/sh echo $@ output..... for i in $@ do echo $i done echo $* output .... for i in $* do echo $i done 输出结果 #sh test.sh a b c d $@ output..... a b c d $* output .... a b c d 从输出结果可以看出 $* 输出是一行 而 $@ 输出则是四行 4. 变量内容的删除与替换 我们在一些情况下,需要对变量中的字符窜进行查找删除或者替换,就需要使用下表列出的方法 变量设定方式说明${变量#关键字}若变量内容从头开始的资料符合‘关键字’,则将符合的最短资料删除${变量##关键字}若变量内容从头开始的资料符合‘关键字’,则将符合的最长资料删除${变量%关键字}若变量内容从尾向前的资料符合‘关键字’,则将符合的最短资料删除${变量%%关键字}若变量内容从尾向前的资料符合‘关键字’,则将符合的最长资料删除${变量/旧字串/新字串}若变量内容符合‘旧字串’则‘第一个旧字串会被新字串取代${变量//旧字串/新字串}若变量内容符合‘旧字串’则‘全部的旧字串会被新字串取代举例如下(删除字符窜中的某个字符): [root@linux ~]# export test_str=/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin [root@linux ~]# echo ${test_str#/*kerberos/bin:}

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档