免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: ccjsj1

[文本处理] 请教awk过滤行中空格或\t [复制链接]

论坛徽章:
17
2015年辞旧岁徽章
日期:2015-03-03 16:54:152017金鸡报晓
日期:2017-02-08 10:39:422017金鸡报晓
日期:2017-01-10 15:19:56JAVA
日期:2016-11-01 13:25:46C
日期:2016-10-25 16:01:4715-16赛季CBA联赛之八一
日期:2016-06-21 23:38:0815-16赛季CBA联赛之山东
日期:2016-05-12 12:49:54IT运维版块每日发帖之星
日期:2016-04-20 06:20:00IT运维版块每日发帖之星
日期:2016-03-22 06:20:00黄金圣斗士
日期:2015-11-24 10:43:13IT运维版块每日发帖之星
日期:2015-08-25 06:20:002015亚冠之德黑兰石油
日期:2015-08-22 22:55:54
发表于 2016-03-09 11:51 |显示全部楼层
回复 8# elu_ligao

多谢了,这个可以的!

将下面内容放到第二个if前面也可以,每行都替换下;
gsub(/\t/,""

   

论坛徽章:
29
程序设计版块每日发帖之星
日期:2016-02-29 06:20:0015-16赛季CBA联赛之天津
日期:2016-08-10 10:33:1115-16赛季CBA联赛之深圳
日期:2016-08-17 15:07:2015-16赛季CBA联赛之佛山
日期:2016-11-07 11:33:5015-16赛季CBA联赛之广夏
日期:2016-11-15 09:13:31CU十四周年纪念徽章
日期:2016-11-24 14:12:25极客徽章
日期:2016-12-07 14:03:4015-16赛季CBA联赛之深圳
日期:2016-12-07 17:15:2715-16赛季CBA联赛之北京
日期:2016-12-22 09:30:0115-16赛季CBA联赛之深圳
日期:2016-12-22 10:49:2115-16赛季CBA联赛之山西
日期:2017-02-10 09:05:3215-16赛季CBA联赛之同曦
日期:2017-02-27 14:19:08
发表于 2016-03-09 11:58 |显示全部楼层
回复 11# ccjsj1


    嗯, 当然, 我看你的代码, 意思好像是3的倍数的行就gsub,else 里面才是3倍数所在行执行的操作

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2016-03-09 12:01 |显示全部楼层
回复 7# Herowinter


    有没有弄错呢?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2016-03-09 12:03 |显示全部楼层
本帖最后由 blackold 于 2016-03-09 12:13 编辑

回复 9# ccjsj1


    不是不行,因为
  1. " "
复制代码
空白地方,人家用的是<tab>,而你用的是<space>。 肯定不行了。

你用/\t/ 或 /\s/ 代替 " " 试试:
  1. awk '{if(NR%3==0) {print gensub(/\t/,"","G",$0)} else {printf("%-20s",$0)}}' urfile
复制代码
  1. awk '{if(NR%3==0) {print gensub(/\s/,"","G",$0)} else {printf("%-20s",$0)}}' urfile
复制代码
或者
  1. awk 'NR%3{printf("%-20s",$0);next}{gsub(/\t/,"");}1' urfile
复制代码

评分

参与人数 1可用积分 +5 收起 理由
ccjsj1 + 5 赞一个!

查看全部评分

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2016-03-09 12:08 |显示全部楼层
回复 8# elu_ligao


    赞!

论坛徽章:
17
2015年辞旧岁徽章
日期:2015-03-03 16:54:152017金鸡报晓
日期:2017-02-08 10:39:422017金鸡报晓
日期:2017-01-10 15:19:56JAVA
日期:2016-11-01 13:25:46C
日期:2016-10-25 16:01:4715-16赛季CBA联赛之八一
日期:2016-06-21 23:38:0815-16赛季CBA联赛之山东
日期:2016-05-12 12:49:54IT运维版块每日发帖之星
日期:2016-04-20 06:20:00IT运维版块每日发帖之星
日期:2016-03-22 06:20:00黄金圣斗士
日期:2015-11-24 10:43:13IT运维版块每日发帖之星
日期:2015-08-25 06:20:002015亚冠之德黑兰石油
日期:2015-08-22 22:55:54
发表于 2016-03-09 12:37 |显示全部楼层
回复 15# blackold
明白了,多谢黑哥!
这末多方法,越来越简练!!

论坛徽章:
448
金牛座
日期:2014-02-26 17:49:58水瓶座
日期:2014-02-26 18:10:15白羊座
日期:2014-04-15 19:29:52寅虎
日期:2014-04-17 19:43:21酉鸡
日期:2014-04-19 21:24:10子鼠
日期:2014-04-22 13:55:24卯兔
日期:2014-04-22 14:20:58亥猪
日期:2014-04-22 16:13:09狮子座
日期:2014-05-05 22:31:17摩羯座
日期:2014-05-06 10:32:53处女座
日期:2014-05-12 09:23:11子鼠
日期:2014-05-21 18:21:27
发表于 2016-03-09 13:17 |显示全部楼层
回复 13# blackold

是我搞错了, 没有替换成功.

   

论坛徽章:
6
羊年新春福章
日期:2015-03-03 17:16:28双子座
日期:2015-03-03 17:16:56巳蛇
日期:2015-03-03 17:17:2415-16赛季CBA联赛之福建
日期:2016-03-11 09:05:00黑曼巴
日期:2016-07-07 16:58:1215-16赛季CBA联赛之吉林
日期:2016-11-14 09:23:07
发表于 2016-03-10 09:09 |显示全部楼层
回复 6# ccjsj1


    我也是在学习,你的思路也很好

论坛徽章:
2
15-16赛季CBA联赛之八一
日期:2016-03-09 16:04:2615-16赛季CBA联赛之佛山
日期:2016-03-16 20:23:14
发表于 2016-03-19 13:16 |显示全部楼层
  1. $ awk  '{sub(/^[ ]+/,"");s=s$0" "};NR%3==0{print s;s="";}' file|column -t
  2. STATUS              ------------        OPEN
  3. SESSION_ACTIVE      --------------      30
  4. SESSION_CURCOUNT    ----------------    463
  5. PROCESSES_ALLCOUNT  ------------------  10000
  6. $ perl -0777ae 'for(0..$#F){$_%3==0 and print "@F[$_..$_+2]\n"}' file|column -t
  7. STATUS              ------------        OPEN
  8. SESSION_ACTIVE      --------------      30
  9. SESSION_CURCOUNT    ----------------    463
  10. PROCESSES_ALLCOUNT  ------------------  10000
  11. $
复制代码

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-10-11 06:20:0015-16赛季CBA联赛之山东
日期:2016-05-28 18:18:5615-16赛季CBA联赛之新疆
日期:2017-04-12 22:55:4715-16赛季CBA联赛之青岛
日期:2017-06-26 18:30:0315-16赛季CBA联赛之四川
日期:2017-09-04 12:27:0315-16赛季CBA联赛之福建
日期:2018-02-09 14:28:3315-16赛季CBA联赛之同曦
日期:2018-04-17 12:43:3415-16赛季CBA联赛之浙江
日期:2018-07-14 13:27:4015-16赛季CBA联赛之吉林
日期:2018-09-13 15:48:2915-16赛季CBA联赛之新疆
日期:2016-05-07 05:05:3215-16赛季CBA联赛之八一
日期:2016-03-14 12:32:06程序设计版块每日发帖之星
日期:2015-12-12 06:20:00
发表于 2016-03-19 23:52 |显示全部楼层
又学到一个新的函数用法,这个在书上好像没见过,不错

回复 5# zxy877298415


   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP