免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 12941 | 回复: 12
打印 上一主题 下一主题

[文本处理] 能否使用sed+正则表达式替换指定行的指定内容 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-12-04 02:25 |只看该作者 |倒序浏览
某文件夹下有三个文件,内容如下
1.txt
$host   = "1.1.1.1";
$host   = "1.1.1.1";
$host   = "1.1.1.1";
$host   = "1.1.1.1";


2.txt
$host   = '11.11.11.11';
$host   = '11.11.11.11';
$host   = '11.11.11.11';
$host   = '11.11.11.11';

3.txt
$host   = <111.111.111.111>;
$host   = <111.111.111.111>;
$host   = <111.111.111.111>;
$host   = <111.111.111.111>;


整理出需要替换内容的列表保存在replace.me的文件里,格式为
文件名:需替换的行号        该行的内容

1.txt:1                $host   = "1.1.1.1";
2.txt:2                $host   = '11.11.11.11';
3.txt:3                $host   = <111.111.111.111>;

能否使用sed+正则表达式将replace.me的文件里每个文件名里出现的ip地址用正则表达式进行匹配,并将匹配到的地址替换为2.2.2.2,替换后的结果为
1.txt
$host   = "2.2.2.2";
$host   = "1.1.1.1";
$host   = "1.1.1.1";
$host   = "1.1.1.1";


2.txt
$host   = '11.11.11.11';
$host   = '2.2.2.2';
$host   = '11.11.11.11';
$host   = '11.11.11.11';

3.txt
$host   = <111.111.111.111>;
$host   = <111.111.111.111>;
$host   = <2.2.2.2>;
$host   = <111.111.111.111>;

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
2 [报告]
发表于 2014-12-04 08:40 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
5
白羊座
日期:2014-10-28 11:23:27水瓶座
日期:2015-01-20 10:19:022015亚冠之柏斯波利斯
日期:2015-07-11 18:17:2015-16赛季CBA联赛之同曦
日期:2015-12-23 12:38:582016猴年福章徽章
日期:2016-02-18 15:30:34
3 [报告]
发表于 2014-12-04 09:02 |只看该作者
本帖最后由 klainogn 于 2014-12-04 09:12 编辑
  1. $ sed -r 's/^(.*):([0-9]+).*=[^0-9]*([0-9\.]+)[^0-9]+$/sed "1F;\2 s#\3#2.2.2.2#" \1/e;' re.me
  2. 1.txt
  3. $host   = "2.2.2.2";
  4. $host   = "1.1.1.1";
  5. $host   = "1.1.1.1";
  6. $host   = "1.1.1.1";
  7. 2.txt
  8. $host   = '11.11.11.11';
  9. $host   = '2.2.2.2';
  10. $host   = '11.11.11.11';
  11. $host   = '11.11.11.11';
  12. 3.txt
  13. $host   = <111.111.111.111>;
  14. $host   = <111.111.111.111>;
  15. $host   = <2.2.2.2>;
  16. $host   = <111.111.111.111>;
复制代码
如果直接修改原文件,修改为以下内容:
  1. sed -r 's/^(.*):([0-9]+).*=[^0-9]*([0-9\.]+)[^0-9]+$/sed -i "\2 s#\3#2.2.2.2#" \1/e;' re.me
复制代码

论坛徽章:
0
4 [报告]
发表于 2014-12-04 09:10 |只看该作者
回复 3# klainogn


     厉害!

论坛徽章:
0
5 [报告]
发表于 2014-12-04 10:11 |只看该作者
3楼对sed中s/e命令的运用确实是妙到豪颠啊,相对而言awk看起来就太臃肿了:

  1. awk 'BEGIN{FS="[: <>;\"'"'"'=]+";while(getline <"replace.me"){a[$1]=$2;b[$1]=$4}} a[FILENAME]==FNR{gsub(b[FILENAME],"2.2.2.2")}{print >FILENAME"new"}' files
复制代码

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
6 [报告]
发表于 2014-12-04 10:24 |只看该作者
回复 5# Looiml
  1. awk -F '[: ]+' '{n=0;while(getline v<$1){if(++n==$2)sub(/\<[0-9.]+\>/,"2.2.2.2",v);print v>$1".new"}}' replace.me
复制代码

论坛徽章:
0
7 [报告]
发表于 2014-12-04 10:49 |只看该作者
回复 6# ly5066113
类似的方式,不过有误,把\< \>拿掉应该就好了,如果人家要匹配到replace.me里的最后一列才做替换的话可能还得改改,不过跟sed比起来,要做原文件替换的话,又得多加些字符。

论坛徽章:
0
8 [报告]
发表于 2014-12-04 10:52 |只看该作者
回复 6# ly5066113
不过客观地讲,兄弟的方法可以准确地找文本文件,不必另外花功夫,值得借鉴。
   

论坛徽章:
0
9 [报告]
发表于 2014-12-04 11:03 |只看该作者
[ 本帖最后由 lnzfm 于 2014-12-04 11:53 编辑 ]

谢谢各位,我有个地方没看懂,麻烦帮我解释一下。
我感觉替换都是在后面的sed "1F;\2 s#\3#2.2.2.2#" \1/e;这部分完成的,可是为什么
s/^(.*):([0-9]+).*=[^0-9]*([0-9\.]+)[^0-9]+$前面这里使用s/替换模式呢?
我们的口号是更短,更快,更简洁

论坛徽章:
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
10 [报告]
发表于 2014-12-04 12:25 |只看该作者
回复 9# lnzfm


    谍中谍,sed中sed。

   这相当于两个sed命令。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP