文件操作

read一次可以为多个变量赋值——但一次只能读一行,比如:

    #!/bin/bash
   #指定分隔符为  “:”
    IFS=:    
    read aa bb cc < /etc/passwd
    echo $aa $bb $cc
    (注:默认shell是无法将/etc/passwd中那些以冒号分割的字符串分割的,通过设置IFS可以实现这一点,详情见本文底部)
    我们将看到的结果是前两个变量被赋予了正确的值,最后一个变量被赋予了文件第一行剩下的所有值。(因为read一次只能读一行)
    而现实中如果一个文件保存了这样一个电话本:
    路人甲  13900000000
    主角A   23320000
    神秘人  12x0x0x0000
    旁白    85600000
    ……
    如果我们要写一个脚本来实现该电话本的查询,通常会这样写:
    #!/bin/bash
    while read name num
    do
    if [ $name = $1 ]
       then echo $num
    fi
    done
    当我们把想查询的人名作为参数来启动脚本,就可以看到他的号码,然后给他打骚扰电话……
    (关于while等流程控制语句,我会在稍后整理)
 
 
   抽取行
    head -x 文件               //抽取前x行
    tail -x 文件               //抽取末尾x行
    sed  -n xp 文件          //抽取文件中的第x行   注:这里的-n就是-n,不代表别的。
 
 
   抽取列
    cut -fx -dy 文件           //以y作为分隔符,抽取第x列
    awk -Fy '{print $x}' 文件  //以y作为分隔符,抽取第x列
                               注:awk可以抽取多列,在指令中使用逗号分割,例:
                               awk -F: '{print $3,$5}' /etc/passwd
                                        将会抽取文件中的第3列和第5列
 
 
   排序
    sort -ty +xn 文件          //以y作为分隔符,以第1+x列为基准排序
    注:如果使用了该指令,则不能在同一语句内使用其它参数,如有需要,只能在管道中再sort一次,如: sort +4n /etc/fstab | sort -r
         其它参数:  n  对数字排序
                   d   对字母排序
                   M   对月份排序(诸如JAN,FEB....DEC之类)
                   r   逆向
 
 
   $IFS
    很多时候我们并不需要指定分隔符,因为$IFS默认包含了空格,\t和换行符。
    只有遇到其它分隔符是我们才需要特别指定,比如$PATH和/etc/passwd中就是以冒号分割,遇到类似这种情况,我们才需要对$IFS进行指定。

你可能感兴趣的:(脚本,F#,XP,bash)