免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1327 | 回复: 8
打印 上一主题 下一主题

求教awk的使用 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-09-14 10:33 |只看该作者 |倒序浏览
我想在awk里使用其它的命令,如grep,echo等。。例如把echo "select * from table"|mysql -D db -N|sed 's/\t/,/g'|grep "tt"的输出用split写到组里。注意,我是想把这条语句写到awk里边。。高手帮帮我吧。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
2 [报告]
发表于 2006-09-14 10:48 |只看该作者
把shell的变量传递给awk处理比较简单明了!

论坛徽章:
0
3 [报告]
发表于 2006-09-14 10:51 |只看该作者
是呀,可是我的awk还要处理其它的文件,echo "select * from table"|mysql -D db -N|sed 's/\t/,/g'|grep "tt"得到的结果只是和那些文件比较。

论坛徽章:
0
4 [报告]
发表于 2006-09-14 11:07 |只看该作者
火兄说的是这样
awk -v a="`echo "select * from table"|mysql -D db -N|sed 's/\t/,/g'|grep "tt"`" 'xxxxxx' urfile

论坛徽章:
0
5 [报告]
发表于 2006-09-14 13:17 |只看该作者
原帖由 guochunning 于 2006-9-14 10:33 发表
我想在awk里使用其它的命令,如grep,echo等。。例如把echo "select * from table"|mysql -D db -N|sed 's/\t/,/g'|grep "tt"的输出用split写到组里。注意,我是想把这条语句写到awk里边。。高 ...



  1. awk -v a="YOURCOMMANDHERE" '
  2. BEGIN{
  3. a | getline x
  4. split(x,array," ")
  5. }
  6. #anything you want to do ..........
  7. '

复制代码

论坛徽章:
0
6 [报告]
发表于 2006-09-14 13:29 |只看该作者
原帖由 苏蓉蓉 于 2006-9-14 13:17 发表




  1. awk -v a="YOURCOMMANDHERE" '
  2. BEGIN{
  3. a | getline x
  4. split(x,array," ")
  5. }
  6. #anything you want to do ..........
  7. '

复制代码


可是我在-v里得到的是一个多行的变量,在BEGIN里我想把每行的记录都单独出来,应该怎么办呢?

论坛徽章:
0
7 [报告]
发表于 2006-09-14 13:32 |只看该作者
那就自己想办法吧

论坛徽章:
0
8 [报告]
发表于 2006-09-14 15:04 |只看该作者
如此:

  1. awk 'BEGIN{"shell_command" | getline}'
  2. or
  3. awk 'BEGIN{"shell_command" | getline x }'
复制代码

[ 本帖最后由 lovelyarry 于 2006-9-14 15:09 编辑 ]

论坛徽章:
0
9 [报告]
发表于 2006-09-14 15:10 |只看该作者
The built-in function getline sets $0 to the next input record from
      the current input file; getline < file sets $0 to the next record from
      file.  getline x sets variable x instead.  Finally, cmd | getline
      pipes the output of cmd into getline; each call of getline returns the
      next line of output from cmd.  In all cases, getline returns 1 for a
      successful input, 0 for end of file, and -1 for an error.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP