Chinaunix首页 | 论坛 | 博客
  • 博客访问: 310534
  • 博文数量: 84
  • 博客积分: 5016
  • 博客等级: 大校
  • 技术积分: 900
  • 用 户 组: 普通用户
  • 注册时间: 2006-12-30 20:22
文章分类

全部博文(84)

文章存档

2008年(21)

2007年(63)

我的朋友

分类:

2007-10-26 00:28:04

    有的时候,出于娱乐需要,我们会从文件中抽取字符串来为变量赋值,这时可以使用read来实现。
    (旁白:出于娱乐需要……)
    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进行指定。
阅读(1453) | 评论(0) | 转发(0) |
0

上一篇:匹配归类

下一篇:流程控制基础

给主人留下些什么吧!~~