原帖由 我是DBA 于 2009-3-1 20:40 发表
[test@erpdataserver ~]$ awk -v RS='[' '$1=$1{print "["$1,(NF-1)}' 1
[11235334] 2
[23432423] 1
[test@erpdataserver ~]$ cat 1
[11235334]
13454543454
13643543544
[23432423]
13654645542
[11235334]
13443253457
13443253456
13443253456
13443253456
13443253456
13443253456
13443253456
13443253456
[11235335]
13443253456
13443253456
13443253459
13443253456
13443253456
13443253456
13443253456
13443253456
[rockfall@tmp]$cat urfile2
[11235334]
13454543454
13643543544
[23432423]
13654645542
[rockfall@tmp]$tac urfile2 |while read line;do if [[ $line =~ "\[[0-9]*\]" ]] ;then echo $line $count;count=0;else ((count++));fi;done
[23432423] 1
[11235334] 2
原帖由 我是DBA 于 2009-3-1 20:40 发表
[test@erpdataserver ~]$ awk -v RS='[' '$1=$1{print "["$1,(NF-1)}' 1
[11235334] 2
[23432423] 1
[test@erpdataserver ~]$ cat 1
[11235334]
13454543454
13643543544
[23432423]
13654645542
原帖由 我是DBA 于 2009-3-1 20:40 发表
[test@erpdataserver ~]$ awk -v RS='[' '$1=$1{print "["$1,(NF-1)}' 1
[11235334] 2
[23432423] 1
[test@erpdataserver ~]$ cat 1
[11235334]
13454543454
13643543544
[23432423]
13654645542
原帖由 我是DBA 于 2009-3-1 21:40 发表
重置输出分隔符
给你个例子吧
[test@erpdataserver ~]$ cat 1
1 2 3 4
a a a 5 2 7
[test@erpdataserver ~]$ awk '$1=$1' 1
1 2 3 4
a a a 5 2 7
原帖由 我是DBA 于 2009-3-1 21:40 发表
重置输出分隔符
给你个例子吧
[test@erpdataserver ~]$ cat 1
1 2 3 4
a a a 5 2 7
[test@erpdataserver ~]$ awk '$1=$1' 1
1 2 3 4
a a a 5 2 7
1 2 3 4
0 2 3 4
a a a 5 2 7
原帖由 blackold 于 2009-3-1 22:07 发表
在许多语言中,赋值语句($1=value)的真值由所赋的值决定。
在这个例子中,当value为0或者空字符串""时,值为false,不执行默认的action(print $0)。
在awk中$1=value如" 我是DBA" 所说,还在其它的“副作 ...
原帖由 haimming 于 2009-3-1 21:57 发表
[rockfall@tmp]$awk '$1=$1' kkkk
1 2 3 4
a a a 5 2 7
[rockfall@tmp]$cat kkkk
1 2 3 4
0 2 3 4
a a a 5 2 7
[rockfall@tmp]$
0开头的行不见 了
原帖由 blackold 于 2009-3-1 20:51 发表
没有统计具体个数:
awk -F : '{a[$1]=a[$1]"\n"$2}END{for ( i in a ) print "["i"]"a}' urife
输出为:
本人毕业不到一年,在Linux下也没什么经验,以前在学校基本上没接触过linux,不过以后想在linux下发展,于是就去应聘Linux下的搜索工程师,简历上写了熟悉shell编程(呵呵,其实只是勉强知道一些),结果面试官一上来就出了一个题,大致是这样的:有一个文件是QQ号到手机号的绑定关系,一行一个关系,格式如下:11235334:13443253456。然后统计出每个QQ绑定了几个手机,输出到一个文件里。格式如下
:[11235334]
13454543454
13643543544
[23432423]
13654645542
结果一下子就闷了,后来的问题也就没什么意义了,真是失败,看来现在要恶补了,哪位哥们帮忙解答一下上面的问题,随便给点意见,我选择Linux是不是一个错误???
原帖由 xinxin12375 于 2009-3-1 20:26 发表
本人毕业不到一年,在Linux下也没什么经验,以前在学校基本上没接触过linux,不过以后想在linux下发展,于是就去应聘Linux下的搜索工程师,简历上写了熟悉shell编程(呵呵,其实只是勉强知道一些),结果面试官一 ...
原帖由 xinxin12375 于 2009-3-1 20:26 发表
本人毕业不到一年,在Linux下也没什么经验,以前在学校基本上没接触过linux,不过以后想在linux下发展,于是就去应聘Linux下的搜索工程师,简历上写了熟悉shell编程(呵呵,其实只是勉强知道一些),结果面试官一 ...
原帖由 zhangjiakouzf 于 2009-3-2 14:11 发表
那天我也去了,你是在深圳还是在北京?
他明确的说了让你用shell命令来实现了吗?如果没有的话,我觉得他在问算法!!
我那天没碰到这个问题,如果问我,我会说用 trie tree 来进行关键字统计,并其在 ...
原帖由 我是DBA 于 2009-3-1 20:40 发表
[test@erpdataserver ~]$ awk -v RS='[' '$1=$1{print "["$1,(NF-1)}' 1
[11235334] 2
[23432423] 1
[test@erpdataserver ~]$ cat 1
[11235334]
13454543454
13643543544
[23432423]
13654645542
原帖由 我是DBA 于 2009-3-1 20:40 发表
[test@erpdataserver ~]$ awk -v RS='[' '$1=$1{print "["$1,(NF-1)}' 1
[11235334] 2
[23432423] 1
[test@erpdataserver ~]$ cat 1
[11235334]
13454543454
13643543544
[23432423]
13654645542
原帖由 zhangjiakouzf 于 2009-3-2 14:11 发表
那天我也去了,你是在深圳还是在北京?
他明确的说了让你用shell命令来实现了吗?如果没有的话,我觉得他在问算法!!
我那天没碰到这个问题,如果问我,我会说用 trie tree 来进行关键字统计,并其在 ...
原帖由 xinxin12375 于 2009-3-2 23:23 发表
我在深圳,唉,如果问你那种问题就好了,我擅长的就是算法和网络编程,你那个问题是个老题目了,用最小堆就可以了,先读50个数到内存,调整成最小堆,然后依次读剩下的数,和堆顶元素比较,比堆顶大的话就将 ...
原帖由 justlooks 于 2009-3-2 09:22 发表
sort -k1 dfile2|awk -F":" -v num=0 '{if($1!=num){num=$1;print "["num"]";}print $2}'
原帖由 blackold 于 2009-3-1 20:51 发表
没有统计具体个数:
awk -F : '{a[$1]=a[$1]"\n"$2}END{for ( i in a ) print "["i"]"a}' urife
输出为:
欢迎光临 Chinaunix (http://bbs.chinaunix.net/) | Powered by Discuz! X3.2 |