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

一些简单shell实例

[复制链接]

尚未签到

发表于 2018-8-29 09:55:20 | 显示全部楼层 |阅读模式
  1.模拟linnux登录shell

  •   #!/bin/bash
  •   echo -n "login:"
  •   read name
  •   echo -n "password:"
  •   read passwd
  •   if [ $name = "cht" -a $passwd = "abc" ];then
  •   echo "the host and password is right!"
  •   else echo "input is error!"
  •   fi
  2.比较两个数大小

  •   #!/bin/bash
  •   echo "please enter two number"
  •   read a
  •   read b
  •   if test $a -eq $b
  •   then echo "NO.1 = NO.2"
  •   elif test $a -gt $b
  •   then echo "NO.1 > NO.2"
  •   else echo "NO.1 < NO.2"
  •   fi
  3.查找/root/目录下是否存在该文件

  •   #!/bin/bash
  •   echo "enter a file name:"
  •   read a
  •   if test -e /root/$a
  •   then echo "the file is exist!"
  •   else echo "the file is not exist!"
  •   fi
  4.for循环的使用

  •   #!/bin/bash
  •   clear
  •   for num in 1 2 3 4 5 6 7 8 9 10
  •   do
  •   echo "$num"
  •   done
  5.查看是否当前用户

  •   #!/bin/bash
  •   echo "Please enter a user:"
  •   read a
  •   b=$(whoami)
  •   if test $a = $b
  •   then echo "the user is running."
  •   else echo "the user is not running."
  •   fi
  6.删除当前目录下大小为0的文件

  •   #!/bin/bash
  •   for filename in `ls`
  •   do
  •   if test -d $filename
  •   then b=0
  •   else
  •   a=$(ls -l $filename | awk '{ print $5 }')
  •   if test $a -eq 0
  •   then rm $filename
  •   fi
  •   fi
  •   done
  7.如果/export/um_lpp_source下有文件,那么将其文件系统大小改为3G

  •   #!/bin/bash
  •   while line=`ls /export/um_lpp_source`
  •   do
  •   if test $line=""
  •   then echo "NULL"
  •   sleep 1
  •   else echo $line

  •   chfs -a>
  •   exit 0
  •   fi
  •   done
  8.测试IP地址

  •   #!/bin/bash
  •   for i in 1 2 3 4 5 6 7 8 9
  •   do
  •   echo "the number of $i computer is "
  •   ping -c 1 192.168.0.$i
  •   done
  9.如果test.log的大小大于0,那么将/opt目录下的*.tar.gz文件拷贝到当前目录下

  •   #!/bin/sh
  •   a=2
  •   while name="test.log"
  •   do
  •   sleep 1
  •   b=$(ls -l $name | awk '{print $5}')
  •   if test $b -gt $a
  •   then `cp /opt/*.tar.gz .`
  •   exit 0
  •   fi
  •   done
  10.打印读取的内容,为下面的例子做准备

  •   #!/bin/bash
  •   while read name
  •   do
  •   echo $name
  •   done
  11.从0.sh中读取内容并打印

  •   #!/bin/bash
  •   while read line
  •   do
  •   echo $line
  •   done < 0.sh
  12.读取a.c中的内容并做加1运算

  •   #!/bin/bash
  •   test -e a.c
  •   while read line
  •   do
  •   a=$(($line+1))
  •   done < a.c
  •   echo $a
  13.普通无参数函数

  •   #!/bin/bash
  •   p ()
  •   {
  •   echo "hello"
  •   }
  •   p
  14.给函数传递参数

  •   #!/bin/bash
  •   p_num ()
  •   {
  •   num=$1
  •   echo $num
  •   }
  •   for n in $@
  •   do
  •   p_num $n
  •   done
  15.创建文件夹

  •   #!/bin/bash
  •   while :
  •   do
  •   echo "please input file's name:"
  •   read a
  •   if test -e /root/$a
  •   then
  •   echo "the file is existing Please input new file name:"
  •   else
  •   mkdir $a
  •   echo "you aye sussesful!"
  •   break
  •   fi
  •   done
  16.获取本机IP地址

  •   #!/bin/bash
  •   ifconfig | grep "inet addr:" | awk '{ print $2 }'| sed 's/addr://g'
  17.查找最大文件

  •   #!/bin/bash
  •   a=0
  •   for name in *.*
  •   do
  •   b=$(ls -l $name | awk '{print $5}')
  •   if test $b -gt $a
  •   then a=$b
  •   namemax=$name
  •   fi
  •   done
  •   echo "the max file is $namemax"
  18.查找当前网段内IP用户,重定向到ip.txt文件中

  •   #!/bin/bash
  •   a=1
  •   while :
  •   do
  •   a=$(($a+1))
  •   if test $a -gt 255
  •   then break
  •   else
  •   echo $(ping -c 1 192.168.0.$a | grep "ttl" | awk '{print $4}'| sed 's/://g')
  •   ip=$(ping -c 1 192.168.0.$a | grep "ttl" | awk '{print $4}'| sed 's/://g')
  •   echo $ip >> ip.txt
  •   fi
  •   done
  19.打印当前用户

  •   #!/bin/bash
  •   echo "Current User is :"
  •   echo $(ps | grep "$$" | awk '{print $2}')
  20.case语句练习

  •   #!/bin/bash
  •   clear
  •   echo "enter a number from 1 to 5:"
  •   read num
  •   case $num in
  •   1) echo "you enter 1"
  •   ;;
  •   2) echo "you enter 2"
  •   ;;
  •   3) echo "you enter 3"
  •   ;;
  •   4) echo "you enter 4"
  •   ;;
  •   5) echo "you enter 5"
  •   ;;
  •   *) echo "error"
  •   ;;
  •   esac
  21.yes/no返回不同的结构

  •   #!/bin/bash
  •   clear
  •   echo "enter [y/n]:"
  •   read a
  •   case $a in
  •   y|Y|Yes|YES) echo "you enter $a"
  •   ;;
  •   n|N|NO|no) echo "you enter $a"
  •   ;;
  •   *) echo "error"
  •   ;;
  •   esac
  22.内置命令的使用

  •   #!/bin/bash
      clear
      echo "Hello, $USER"

      echo "Today 's date>  echo "the user is :"
      who
      echo "this is `uname -s`"
      echo "that's all folks! "

  23.打印无密码用户

  •   #/bin/bash
  •   echo "No Password User are :"
  •   echo $(cat /etc/shadow | grep "!!" | awk 'BEGIN { FS=":" }{print $1}')
  参考:http://blog.chinaunix.net/uid-28804901-id-3874633.html


运维网声明 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.yunweiku.com/thread-558030-1-1.html 上篇帖子: Linux shell扩展用法 下篇帖子: Linux Shell常用技巧(三) sed
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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