免费注册 查看新帖 |

Chinaunix

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

如果筛选字段呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-08 17:39 |只看该作者 |倒序浏览
  1. username: zhengzhu
  2. add: china
  3. age: 23
  4. pass: yes
  5. marry: yes
  6. tel: 2312423

  7. username: gsdfsdf
  8. add: USA
  9. age: 34
  10. pass: yes
  11. tel: 9878676

  12. username: zhk
  13. add: china
  14. age: 50
  15. pass: no
  16. live: guangzhou
复制代码


如上的文件中,我需要的最终结果如下:

  1. zhengzhu china 23 yes
  2. gsdfsdf        USA 34        yes
  3. zhk        china        50        no
复制代码


谢谢.

论坛徽章:
0
2 [报告]
发表于 2010-01-08 17:47 |只看该作者
是不是需要定义ORS呢?
但是ORS应该设为什么呢?

论坛徽章:
0
3 [报告]
发表于 2010-01-08 18:00 |只看该作者
  1. user@ubuntu:~/script$ awk 'BEGIN{FS=":"}{if($0~"^$") print $0;else printf $2}' file|cut -d " " -f2-5
  2. zhengzhu china 23 yes
  3. gsdfsdf USA 34 yes
  4. zhk china 50 no
复制代码

论坛徽章:
0
4 [报告]
发表于 2010-01-08 18:12 |只看该作者

  1. awk -v RS='\n\n' -v FS=': |\n' '{print $2" "$4" "$6" "$8}'
复制代码

论坛徽章:
0
5 [报告]
发表于 2010-01-08 18:31 |只看该作者
原帖由 lululau 于 2010-1-8 18:12 发表

awk -v RS='\n\n' -v FS=': |\n' '{print $2" "$4" "$6" "$8}'


但是有些字段是不一样的排列顺序:

  1. username: zhengzhu
  2. add: china
  3. age: 23
  4. pass: yes
  5. marry: yes
  6. tel: 2312423

  7. username: gsdfsdf
  8. add: USA
  9. age: 34
  10. pass: yes
  11. tel: 9878676

  12. username: zhk
  13. add: china
  14. age: 50
  15. pass: no
  16. live: guangzhou

  17. username: jacky
  18. add: china
  19. tel: 89873
  20. age: 50
  21. email: [email]jacky@163.com[/email]
  22. pass: no
  23. live: guangzhou

  24. username: juny
  25. add: CA
  26. age: 50
  27. email: [email]jacky@163.com[/email]
  28. pass: no
  29. live: BG
复制代码

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
6 [报告]
发表于 2010-01-08 19:42 |只看该作者

  1. awk '/^username:/||/^add:/||/^age:/||/^pass:/{print $2}' urfile | awk '{ORS=NR%4?" ":"\n";print $NF}'
复制代码

论坛徽章:
0
7 [报告]
发表于 2010-01-08 20:19 |只看该作者

  1. perl -ne '
  2. BEGIN{$/="\n\n";$,=" "}
  3. my $h;
  4. for(split /\n/){
  5. @r = split /: /;
  6. $h->{$r[0]}=$r[1];
  7. }
  8. push @$a, $h;
  9. END{print $_->{username}, $_->{add}, $_->{age}, $_->{pass}, "\n" for @$a;}
复制代码

论坛徽章:
0
8 [报告]
发表于 2010-01-08 21:34 |只看该作者
  1. awk '/username/{if (n) print n,add,age,p;n=$2}/add:/{add=$2}/age:/{age=$2}/pass:/{p=$2}END{print n,add,age,p}' file
复制代码

论坛徽章:
0
9 [报告]
发表于 2010-01-08 22:23 |只看该作者
原帖由 ywlscpl 于 2010-1-8 21:34 发表
awk '/username/{if (n) print n,add,age,p;n=$2}/add:/{add=$2}/age:/{age=$2}/pass:/{p=$2}END{print n,add,age,p}' file

这个可读性好

论坛徽章:
0
10 [报告]
发表于 2010-01-08 22:53 |只看该作者
原帖由 ywlscpl 于 2010-1-8 21:34 发表
awk '/username/{if (n) print n,add,age,p;n=$2}/add:/{add=$2}/age:/{age=$2}/pass:/{p=$2}END{print n,add,age,p}' file

能不能解释一下这一段
{if (n) print n,add,age,p;n=$2}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP