Linux Shell 文件操作

上一篇 / 下一篇  2009-06-05 17:22:16 / 个人分类:Linux

我的栏目
  • 栏目:Linux
有的时候,出于娱乐需要,我们会从文件中抽取字符串来为变量赋值,这时可以使用read来实现。51Testing软件测试网 wl4y0PL2k%irq

1bq k aI8a0
    (旁白:出于娱乐需要……)
    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进行指定。

TAG: file File Linux linux shell Shell

 

评分:0

我来说两句

日历

« 2024-03-27  
     12
3456789
10111213141516
17181920212223
24252627282930
31      

数据统计

  • 访问量: 231706
  • 日志数: 135
  • 图片数: 4
  • 文件数: 1
  • 书签数: 1
  • 建立时间: 2006-12-11
  • 更新时间: 2022-10-31

RSS订阅

Open Toolbar