Board logo

标题: [讨论]sed,将一行中第2到第6个字符替换成*号 [打印本页]

作者: pooronce     时间: 2008-7-16 00:00    标题: [讨论]sed,将一行中第2到第6个字符替换成*号

各位玩sed的朋友试试吧
刚开始觉得简单,但后来发现有点问题,就是不足6个字符的行,容易给多加出*号来

思考了一会儿,弄了个方案来,但很长,不满意,暂时就不贴出来献丑了,先看看各位朋友的解决方案吧 xD
作者: pooronce     时间: 2008-7-16 00:06
试了下,用gawk来解决倒是很简单
gawk 'BEGIN{FS=OFS=""}{a=NF;for (i=2;i^<7;i++) $i="*";NF=a;print}' ee.txt>aa.txt

再想起来,就算直接用dos批处理来做也简单的
不过还是试试用sed吧,当是个训练,嘿嘿
作者: HAT     时间: 2008-7-16 10:10

sed "s/\(..\)....\(.*\)/\1\*\*\*\*\2/" a.txt

作者: pooronce     时间: 2008-7-17 01:18


  Quote:
Originally posted by HAT at 2008-7-16 10:10 AM:
sed "s/\(..\)....\(.*\)/\1\*\*\*\*\2/" a.txt

误解意思了,第2到第6个,也就是5个字符变星号
另外顶楼就说了,要注意的是,不够6个字符的行,不小心会多加出星号来,比如只有3个字符的行,要么就是没替换到,要么呢就是给多加了3个星号出来
作者: pooronce     时间: 2008-7-17 14:18
贴一下我的解决方案吧:
sed -r -i 'h;s/(.).{1,5}(.*)/\1\2/;x;s/(.{6}).*/\1/;s/.//;:a;/./{s/.//;x;s/(.)/\1*/;x;ba};x;' test.txt

作者: HAT     时间: 2008-7-17 17:12
CU有人给出了一个简洁的方法
sed '{s/./*/2;s/./*/3;s/./*/4;s/./*/5;s/./*/6;}' urfile

作者: 26933062     时间: 2008-7-17 17:24


  Quote:
Originally posted by HAT at 2008-7-17 17:12:
CU有人给出了一个简洁的方法
sed '{s/./*/2;s/./*/3;s/./*/4;s/./*/5;s/./*/6;}' urfile

赞,确实是高。。。
这样的代码就向魔术,不知道答案前觉得高深莫测,知道后发现确实简单。!
作者: pooronce     时间: 2008-7-18 16:26


  Quote:
Originally posted by HAT at 2008-7-17 05:12 PM:
CU有人给出了一个简洁的方法
sed '{s/./*/2;s/./*/3;s/./*/4;s/./*/5;s/./*/6;}' urfile

原来可以这样确定匹配空间的,太好了,学到了 xD

有这方法,很多地方都简单多了,像上面,害得我转n个圈用循环才解决好哪-_-#


btw:请问,你说的CU是指哪里啊
作者: HAT     时间: 2008-7-18 16:45
CU: ChinaUnix
http://bbs.chinaunix.net/forum-24-1.html
作者: pooronce     时间: 2008-7-18 17:48
噢。。。原来是chinaunix啊,原来兄弟混迹那里的 xD