免费注册 查看新帖 |

Chinaunix

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

[文本处理] 如何实现文本内容替换 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-09-27 14:03 |只看该作者 |倒序浏览
  1. [erpts_pd1]
  2. database = pd1
  3. host = 10.24.5.3
  4. isolation_level = DATABASE_SETTING
  5. password = enc:+dAaASt9cdtpVDw==
  6. port = 1601
  7. readonly = 1
  8. type = oracle
  9. username = system
  10. disabled = 0

  11. [tiyandian-ksxt_inventory]
  12. database = inventory
  13. host = 10.2.1.65
  14. isolation_level = DATABASE_SETTING
  15. password = enc:ajp7z9mPc/macdQ==
  16. port = 3306
  17. readonly = 1
  18. type = mysql
  19. username = inventory
  20. disabled = 0

  21. [server1_a_mes]
  22. database = a_mes
  23. host = 10.2.1.2
  24. isolation_level = DATABASE_SETTING
  25. password = enc:7qavvVE2bZxMfy02JQ==
  26. port = 1433
  27. readonly = 1
  28. type = mssql
  29. username = sa
复制代码
如上的文本内容,如何实现把"[xxx]"的内容改为:
10.2.1.2_mssql_a_mes


就是把每一区域内的内容的host,type和database字段找出来,然后组成[]内的内容。


谢谢。

论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
2 [报告]
发表于 2018-09-27 17:26 |只看该作者
本帖最后由 WilliBhamlll 于 2018-09-27 17:57 编辑
  1. awk -F'[= ]+' 'NR==FNR{if(/^\[/){s=$0;next}{if(/^host|^type/){a[s]=a[s]?a[s]"_"$2:$2}}next}a[$0]{sub(/[^_]+_/,"["a[$0]"_")}1' file file
复制代码

论坛徽章:
1
15-16赛季CBA联赛之山东
日期:2018-10-09 17:18:30
3 [报告]
发表于 2018-09-27 19:11 |只看该作者
sed -i 's/^\[.*\]$/\[10.2.1.2_mssql_a_mes\]/g' file

论坛徽章:
0
4 [报告]
发表于 2018-09-27 20:13 |只看该作者
本帖最后由 cd_chair 于 2018-09-27 20:15 编辑
  1. awk 'BEGIN{RS=ORS="\n\n";FS=OFS="\n"}{split($2,a," = ");split($3,b," = ");split($8,c," = ");gsub(/\[(.*)\]/,"["b[2]"_"c[2]"_"a[2]"]",$1);print $0}'
复制代码

论坛徽章:
0
5 [报告]
发表于 2018-09-28 16:29 |只看该作者
$ awk 'database && host && type { print host"_"type"_"database; database=""; host=""; type="" } { if ($0 ~ /database/) database=$3; if ($0 ~ /host/) host=$3; if ($0 ~ /type/) type=$3}' 1

10.24.5.3_oracle_pd1
10.2.1.65_mysql_inventory
10.2.1.2_mssql_a_mes
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP