标题: [讨论]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