Chinaunix

标题: awk中如何取某个字符串的前三个字符? [打印本页]

作者: king_boss    时间: 2008-06-17 16:09
标题: awk中如何取某个字符串的前三个字符?
有一个类似于这样的文本:
16  001agdcdafasd
16  002agdcxxxxxx
23  001adfadfahoh
23  001fsdadggggg

我想要得到
16  001
16  002
23  001
23  002
在awk中,就是取$2的前三个字符,但是不知道如何处理
大家帮帮忙哦,先谢谢了:)
作者: 寂寞烈火    时间: 2008-06-17 16:10
awk '{print $1,substr($2,1,3)}'
作者: king_boss    时间: 2008-06-17 16:11
原帖由 king_boss 于 2008-6-17 16:09 发表
有一个类似于这样的文本:
16  001agdcdafasd
16  002agdcxxxxxx
23  001adfadfahoh
23  001fsdadggggg

我想要得到
16  001
16  002
23  001
23  002
在awk中,就是取$2的前三个字符,但是不知道如 ...



已经得到答案了, 用substr()这个函数
awk '{ print $1, substr($2, 1, 3)}'  file就OK了
^_^
作者: king_boss    时间: 2008-06-17 16:26
原帖由 寂寞烈火 于 2008-6-17 16:10 发表
awk '{print $1,substr($2,1,3)}'


呵呵,多谢老法王啦 ~~
作者: woodie    时间: 2008-06-17 16:54
烈火的:正解!
woodie的,怪招:
awk -F"[^0-9]" '{print $2}
Playing and enjoying with shell.^_^

-----
好像有两个空格,还需要第一列,改下:
awk -F"[^0-9]+" '{print $1, $2}'

[ 本帖最后由 woodie 于 2008-6-17 17:37 编辑 ]
作者: lvb1982    时间: 2008-06-17 17:38
awk '{print $1,substr($2,1,3)}'
作者: Shell_HAT    时间: 2008-06-17 17:49
用cut不是很简单吗
  1. cut -c1-7 urfile
复制代码

作者: 寂寞烈火    时间: 2008-06-17 18:23
原帖由 Shell_HAT 于 2008-6-17 17:49 发表
用cut不是很简单吗
cut -c1-7 urfile

简单, 但是如果第一个 域的长度不能确定的时候....
用grep也可吧
grep -o '^.\+ \+...'
作者: zghover    时间: 2008-06-17 19:57
凑个热闹:别把sed忘记了,呵呵





  1. $cat file
  2. 16  001agdcdafasd
  3. 16  002agdcxxxxxx
  4. 23  001adfadfahoh
  5. 23  001fsdadggggg

  6. [***@*** stdshell]$ sed 's/\(.* ...\).*/\1/' file
  7. 16  001
  8. 16  002
  9. 23  001
  10. 23  001
复制代码

作者: ruifox    时间: 2008-06-18 10:31
原帖由 woodie 于 2008-6-17 16:54 发表
烈火的:正解!
woodie的,怪招:
awk -F"[^0-9]" '{print $2}
Playing and enjoying with shell.^_^

-----
好像有两个空格,还需要第一列,改下:
awk -F"[^0-9]+" '{print $1, $2}'


awk -F '[a-z]' '{print $1}'




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2