免费注册 查看新帖 |

Chinaunix

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

[文本处理] shell如何根据输入的关键字找出execl中的列,并根据列的flag显示出需要的内容 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-09-19 21:25 |只看该作者 |倒序浏览
本帖最后由 Desong_Tang 于 2017-09-19 21:31 编辑

说明:
1. execl文档如下;
name
date
sex
1BU01
1BU02
1BU03
A1
B2
C3
0
0
0
A2
B3
C4
1
0
0
A9
B10
C11
0
1
0
A10
B11
C12
0
0
0
A12
B13
C14
0
0
1
AA1
BB1
CC1
1
0
0
AA2
BB2
CC2
0
1
1
2. 运行shell的时候需要输入【关键字】;
3. 根据关键字查询execl与关键字匹配的列;
4. 列中有flag,分别为【1】和【0】;
5. 若flag为【1】,则显示为【1】的那一行。

例如:输入1BU01,则显示A2, B3, C4; AA1, BB1, CC1。

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [报告]
发表于 2017-09-19 22:20 |只看该作者
回复 1# Desong_Tang

$ awk -vk=1BU01 'FNR==1&&/name/{for(n=1;n<=NF;++n)if($n==k)m=n;next}$m{OFS=", ";NF=3;s=s"; "$0}END{sub("; ","",s);print s}' file
A2, B3, C4; AA1, BB1, CC1

论坛徽章:
0
3 [报告]
发表于 2017-09-20 14:11 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
4 [报告]
发表于 2017-09-20 18:30 |只看该作者
本帖最后由 wh7211 于 2017-09-20 18:32 编辑

回复 1# Desong_Tang

先把excel另存为csv文档1.csv。
  1. awk -F"," -vs="1BU01" 'NR==1{for(i=1;i<=NF;i++){t=s==$i?i:t}}{for(i=1;i<=NF;i++){if(i==t&&$i==1){a=a?a";"$1","$2","$3:$1","$2","$3}}}END{print a}' 1.csv
复制代码

输出:
A2,B3,C4;AA1,BB1,CC1

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
5 [报告]
发表于 2017-09-20 18:59 |只看该作者
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. chomp(my $k = <STDIN>);
  5. my ($n) = do {chomp($_ = <DATA>); @ARGV = split(/,/);  grep {$k eq $ARGV[$_]} 0 .. $#ARGV};
  6. while(<DATA>){
  7.         chomp(my @items = split(/,/));
  8.         if($items[$n]){
  9.                 print;
  10.         }
  11. }

  12. __DATA__
  13. name,date,sex,1BU01,1BU02,1BU03
  14. A1,B2,C3,0,0,0
  15. A2,B3,C4,1,0,0
  16. A9,B10,C11,0,1,0
  17. A10,B11,C12,0,0,0
  18. A12,B13,C14,0,0,1
  19. AA1,BB1,CC1,1,0,0
  20. AA2,BB2,CC2,0,1,1
复制代码

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
6 [报告]
发表于 2017-09-20 19:01 |只看该作者
回复 3# 本友会机友会摄友会
大师,在 where 中如何引用属性?给个例子?

论坛徽章:
0
7 [报告]
发表于 2017-09-20 21:53 |只看该作者
大师

论坛徽章:
0
8 [报告]
发表于 2017-09-21 14:55 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP