免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1657 | 回复: 4

[文本处理] 保卫包围数字"$100$" [^[@[0-9]+]] [复制链接]

论坛徽章:
6
程序设计版块每日发帖之星
日期:2016-05-11 06:20:00操作系统版块每日发帖之星
日期:2016-05-12 06:20:00每日论坛发贴之星
日期:2016-05-12 06:20:00操作系统版块每日发帖之星
日期:2016-05-14 06:20:00程序设计版块每日发帖之星
日期:2016-05-31 06:20:00每日论坛发贴之星
日期:2016-05-31 06:20:00
发表于 2018-06-11 08:47 |显示全部楼层
# [ /home/soio/1bs/awks ] {2018-06-11 08:39:41}
: 1528677581:0;➜  awk '{split($0,a,"[^[@[0-9]+]]",b);for(i in a){printf a[i]}}' 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]fee[@8]eeee[@12]eeeeeee[@9]ff#                                                                                                           

# [ /home/soio/1bs/awks ] {2018-06-11 08:40:16}
: 1528677616:0;➜  cat 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]f
ee[@8]eeee[@12]eeeeeee[@9]ff



论坛徽章:
4
15-16赛季CBA联赛之青岛
日期:2018-07-09 14:17:2815-16赛季CBA联赛之八一
日期:2018-08-06 15:30:0515-16赛季CBA联赛之广东
日期:2018-08-09 09:11:2115-16赛季CBA联赛之佛山
日期:2019-02-14 09:26:31
发表于 2018-06-11 10:15 |显示全部楼层
本帖最后由 christmas1102 于 2018-06-11 10:16 编辑
  1. egrep '[^@0-9]|^[0-9]+' --color=always FILE
复制代码

论坛徽章:
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
发表于 2018-06-11 17:13 |显示全部楼层
回复 1# 1cpuer


  1. 你的正则写法有问题,参考下面代码
  2. awk '{patsplit($0,a,"\\[@[0-9]+]",b);for(i in a){printf("%s|",a[i])};printf("%s"," -> ");for(i in b){printf("%s|",b[i])};print ""}' 1
  3. [@7]|[@6]|[@13]|[@9]| -> 12|sss|ssssssss|dd|f|
  4. [@8]|[@12]|[@9]| -> ee|eeee|eeeeeee|ff|
复制代码

论坛徽章:
6
程序设计版块每日发帖之星
日期:2016-05-11 06:20:00操作系统版块每日发帖之星
日期:2016-05-12 06:20:00每日论坛发贴之星
日期:2016-05-12 06:20:00操作系统版块每日发帖之星
日期:2016-05-14 06:20:00程序设计版块每日发帖之星
日期:2016-05-31 06:20:00每日论坛发贴之星
日期:2016-05-31 06:20:00
发表于 2018-06-12 04:35 |显示全部楼层
本帖最后由 1cpuer 于 2018-06-12 04:47 编辑

# [ /home/soio/1bs/awks ] {2018-06-12 04:24:03}
: 1528748643:0;➜  grep -E "\\[@[0-9]+\\]" 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]f
ee[@8]eeee[@12]eeeeeee[@9]ff


# [ /home/soio/1bs/awks ] {2018-06-12 04:24:07}
: 1528748647:0;➜  grep -E "\[@[0-9]+\]" 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]f
ee[@8]eeee[@12]eeeeeee[@9]ff

"[^[@[0-9]+]]" #可是要取反真麻烦 !

# [ /home/soio/1bs/awks ] {2018-06-12 04:38:19}
: 1528749499:0;➜  grep -E "[^@0-9+]" 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]f
ee[@8]eeee[@12]eeeeeee[@9]ff

# 12[@7]
# 前面数字 12 没取到


# [ /home/soio/1bs/awks ] {2018-06-12 04:44:24}
: 1528749864:0;➜  grep -E "^[0-9]+|[^@0-9+]" 1.kk.kf
12[@7]sss[@6]ssssssss[@13]dd[@9]f
ee[@8]eeee[@12]eeeeeee[@9]ff

# 郁闷恰似成功

论坛徽章:
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
发表于 2018-06-12 09:37 |显示全部楼层
本帖最后由 wh7211 于 2018-06-12 09:58 编辑

回复 4# 1cpuer


"[^[@[0-9]+]]" #可是要取反真麻烦 !
  1. 纠正一下,这样写不是你想要的取反
  2. 『[]』表示“匹配一组字符中任一个”
  3. 『[^]』表示“匹配不在指定组内的字符”
  4. 『[^123]』:表示不是1,或不是2,或不是3,并非“不是一百二十三”的意思
  5. 『[^[0-9]+]』:表示不是数字,或不是“+”,并非“不是1到多个数字”的意思
  6. echo "233"|awk '{if(/[^123]/){print "ok"}else{print "false"}}'
  7. false
  8. echo "+"|awk '{if(/[^\\\[0-9\\\]+]/){print "ok"}else{print "false"}}'
  9. false
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP