免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 1596 | 回复: 17

[文本处理] 文本处理求助-指定列清空 [复制链接]

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
发表于 2017-01-03 14:00 |显示全部楼层
本帖最后由 bikkuri 于 2017-01-03 14:27 编辑

大家好!
我有一个问题向大家请教。
有这样一个文本:
Channel BSSID                Encryption           Crypto  WPS  Strength Mode     EXTCH RSSI SSID
------------------------------------------------------------------------------------------------
6       fc:d7:33:fd:d7:fc    WPA1PSKWPA2PSK       AES      NO      0 11b/g/n      BELOW   47 'TP-LINK_D7FC'
11      24:69:68:8f:dc:4c    WPA1PSKWPA2PSK       AES      NO      0 11b/g/n      BELOW   47 'TP-LINK_DC4C'
13      28:2c:b2:35:fa:e0    WPA1PSKWPA2PSK       AES      YES     0 11b/g/n      BELOW   47 'TP-LINK_35FAE0'
1       00:0e:e8:b1:9d:4c    WEP                           NO      0 11b/g/n      ABOVE   18 'TOTOLINK'
11      28:f3:66:b0:c0:f6    WPA2PSK              AES      YES     0 11b/g/n      BELOW   42 '000000'
13      d0:c7:c0:87:d0:62    WPA1PSKWPA2PSK       AES      YES     0 11b/g/n      BELOW   37 'TP-LINK_206'
10      c8:e7:d8:0a:aa:6c    WPA1PSKWPA2PSK       TKIPAES  NO      0 11b/g/n      BELOW   37 'NOKIA'
如果在文本中表头里有WPS则希望把每一行的第60-62个字符的位置,也就是显示NO或者YES的位置,用三个空格替换掉。
如果没有WPS,则文本中不会有NO或者YES,则不做任何处理。
即处理后变为:

Channel BSSID                Encryption           Crypto  W    Strength Mode     EXTCH RSSI SSID
---------------------------------------------------------   ------------------------------------
6       fc:d7:33:fd:d7:fc    WPA1PSKWPA2PSK       AES              0 11b/g/n      BELOW   47 'TP-LINK_D7FC'
11      24:69:68:8f:dc:4c    WPA1PSKWPA2PSK       AES              0 11b/g/n      BELOW   47 'TP-LINK_DC4C'
13      28:2c:b2:35:fa:e0    WPA1PSKWPA2PSK       AES              0 11b/g/n      BELOW   47 'TP-LINK_35FAE0'
1       00:0e:e8:b1:9d:4c    WEP                                   0 11b/g/n      ABOVE   18 'TOTOLINK'
11      28:f3:66:b0:c0:f6    WPA2PSK              AES              0 11b/g/n      BELOW   42 '000000'
13      d0:c7:c0:87:d0:62    WPA1PSKWPA2PSK       AES              0 11b/g/n      BELOW   37 'TP-LINK_206'
10      c8:e7:d8:0a:aa:6c    WPA1PSKWPA2PSK       TKIPAES          0 11b/g/n      BELOW   37 'NOKIA'
谢谢大家!



论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2017-01-03 14:10 |显示全部楼层
本帖最后由 moperyblue 于 2017-01-03 15:30 编辑
  1. sed -r 's/^(.{59})\S+/\1   /'
复制代码

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
发表于 2017-01-03 14:20 |显示全部楼层
  1. awk -vFIELDWIDTHS='59 3 100' '{$2=" "}1'
复制代码

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
发表于 2017-01-03 14:22 |显示全部楼层
  1. sed -r 's/(.{59})(.{3})/\1   /'
复制代码

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
发表于 2017-01-03 14:27 |显示全部楼层
谢谢大家的帮助,不好意思,我修改了一下条件,能不能再帮我看看?谢谢。

论坛徽章:
18
辰龙
日期:2014-05-21 21:01:4115-16赛季CBA联赛之深圳
日期:2016-12-23 13:51:3815-16赛季CBA联赛之北控
日期:2016-11-28 18:26:3815-16赛季CBA联赛之佛山
日期:2016-11-03 11:18:5815-16赛季CBA联赛之辽宁
日期:2016-07-10 16:09:4115-16赛季CBA联赛之江苏
日期:2016-02-20 23:09:202015亚冠之塔什干棉农
日期:2015-08-17 19:49:492015年亚洲杯之日本
日期:2015-04-30 01:24:342015年亚洲杯之约旦
日期:2015-04-01 00:37:182015年亚洲杯之沙特阿拉伯
日期:2015-03-02 15:55:40处女座
日期:2014-05-25 10:34:0020周年集字徽章-年
日期:2023-04-23 11:17:52
发表于 2017-01-03 14:32 |显示全部楼层
回复 3# haooooaaa

您的这条命令中设定字段的长度为59,3,100,前面的59和3我可以理解,后面的100则不一定吧,有可能小于100也可能大于100呢?可以用任意长度匹配$3的长度吗?谢谢。

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
发表于 2017-01-03 14:35 |显示全部楼层
  1. awk -vFIELDWIDTHS='59 3 100' 'a&&/^[0-9]/{$2=" "}NR==1&&/WPS/{a=1}1'
复制代码

论坛徽章:
54
2015亚冠之德黑兰石油
日期:2015-07-07 13:00:1615-16赛季CBA联赛之深圳
日期:2016-03-31 09:03:5415-16赛季CBA联赛之辽宁
日期:2016-05-09 20:38:15程序设计版块每日发帖之星
日期:2016-05-12 06:20:0015-16赛季CBA联赛之四川
日期:2016-05-13 15:19:4715-16赛季CBA联赛之福建
日期:2016-05-15 20:24:34每日论坛发贴之星
日期:2016-05-16 06:20:0015-16赛季CBA联赛之吉林
日期:2016-05-26 11:49:4715-16赛季CBA联赛之广东
日期:2016-05-26 13:49:18极客徽章
日期:2016-12-07 14:05:2315-16赛季CBA联赛之广夏
日期:2016-12-20 17:33:532017金鸡报晓
日期:2017-01-10 15:19:56
发表于 2017-01-03 14:41 |显示全部楼层
本帖最后由 haooooaaa 于 2017-01-03 15:48 编辑
  1. sed -r 'x;
  2.         /^$/{x;
  3.               /WPS/!{x;s/^/e/}        
  4.               /WPS/ {x;s/^/@/}
  5.             }
  6.         /@/{x;/^[0-9]/s/(.{59})(.{3})/\1   /;b};/e/x'
复制代码

论坛徽章:
22
2015年亚洲杯之科威特
日期:2015-04-18 15:27:07每日论坛发贴之星
日期:2016-01-27 06:20:0015-16赛季CBA联赛之广夏
日期:2016-03-28 16:20:51程序设计版块每日发帖之星
日期:2016-04-09 06:20:00CU十四周年纪念徽章
日期:2016-05-03 09:35:1415-16赛季CBA联赛之天津
日期:2016-11-18 08:31:3115-16赛季CBA联赛之山西
日期:2016-12-07 16:29:5315-16赛季CBA联赛之八一
日期:2017-01-10 11:34:3415-16赛季CBA联赛之吉林
日期:2017-03-30 22:51:1915-16赛季CBA联赛之广夏
日期:2017-04-13 20:51:52程序设计版块每日发帖之星
日期:2016-01-27 06:20:00每日论坛发贴之星
日期:2015-12-28 06:20:00
发表于 2017-01-03 15:26 |显示全部楼层
  1. awk 'gsub(/NO/," ",$5)'  file
复制代码

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
发表于 2017-01-03 15:30 |显示全部楼层
"NO"要替换成三个空格? 而不是两个?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP