if-for-while

if

help if可以看看if的用法

if ls -l / ;then echo "ok";else echo "no" ;fi

for

for ((i=0;i<10;i++));do echo $i; done

help for里面的words:asd asd asd,word:asd

for i in aaa fff ssss aaaa;do echo $i;done

命令seq,比如seq 33:从1输出到33

for i in `seq 33`;do echo $i;done

while

help while

练习

先统计一下,并用数值法并倒过来排个序:du -a | sort -nr

思想:把统计结果逆序排列,然后开始循环,把第一个是文件的输出即可。

编程:

oldIFS=¥IFS:bash是通过IFS里面的值来进行切割的,之前存的是空格,换行,制表符,这次要换成换行符,不过先保存现场。

IFS=$'\n':加单引号是为了使得\和n合为一体,$表示取它的值

接着``里面是按照逆序r排列的,对用户输入的路径的所有文件和目录的大小信息的数据集,增强for循环遍历里面的每一个元素。

for i in `du -a $1 | sort -nr`; do

  echo $1

  filename=`echo i | awk '{print $2}'` : 利用echo将内容输到awk的输入流,awk对传进来的树数据做切割,打印第二列,最后赋值给filename

  test里面的-f可以检查是否为文件,可以help test

  if [ -f $filename ] ;then 

    echo $filename

    exit 0 :找到最大的文件后就打印并退出小bash

  fi

done

IFS=$oldIFS :恢复现场

练习

读一个文件的每一行,并打印,最后打印总共多少行。

脚本:

答案1:

name=0

oldIFS=$IFS

IFS=$‘n‘ 此处为单引号

for i in `cat read.txt`;do 此处为反引号,告诉它是命令

  echo i

  ((num++))

done

echo num:$num

IFS=$oldIFS

答案2:

num=0

lines=`cat data | wc -l`  : 拿到行数,且不显示文件名

for ((i=0;i<ilnes;i++));do

  line=`head -$i data | tail -1` :先输出前i行,然后取其中的倒数后一行,给变量line(tail是取倒数后几行的)

  echo line

  ((num++))

done

echo num:$num

答案3:

num=0

先执行一次done后面的,把data文件里的数据放到read的输入流里面,然后read一次循环一次

while read line ;do

  echo $line

  ((num++))

done < data

echo num:$num

答案4:

export num=0

cat data | (while read line ;do 此处将cat的结果放到输入流里面,注意此处管道创建了2个进程,()又创建了1个子进程,若不加小括号,则done;后面的实际上已经返回父进程了

  echo $line

  ((num++))

  done; echo num:$num ) 

答案5:

export num=0

cat data | {while read line ;do

  echo $line

  ((num++))

  done; echo num:$num ;} 此处换成大括号了,且末尾得有;,这次总共只创建了2个进程了

$#和$@区别

echo $# == echo $@

for i in "$*";do 此时$*会把参数列表作为1个元素

for i in "$@";do 此时$@会把参数列表的内容分别作为元素

 

posted @ 2019-06-19 12:43  Jary霸  阅读(170)  评论(0编辑  收藏  举报