免费注册 查看新帖 |

ChinaUnix.net

  平台 论坛 博客 文库 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 784 | 回复: 4

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

论坛徽章:
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
发表于 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
发表于 2018-09-27 19:11 |显示全部楼层
sed -i 's/^\[.*\]$/\[10.2.1.2_mssql_a_mes\]/g' file

论坛徽章:
0
发表于 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
发表于 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
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

数据风云,十年变迁
DTCC 第十届中国数据库技术大会已启航!

2019年5月8日~5月10日,由IT168旗下ITPUB企业社区平台主办的第十届中国数据库技术大会(DTCC2019),将在北京隆重召开。大会将邀请百余位行业专家,就热点技术话题进行分享,是广大数据领域从业人士的又一次年度盛会和交流平台。与SACC2018类似,本届大会将采用“3+2”模式:3天传统技术演讲+2天深度主题培训。大会不仅提供超100场的主题演讲,还会提供连续2天的深度课程培训,深化数据领域的项目落地实践方案。
DTCC2019,一场值得期待的数据技术盛会,殷切地希望您报名参与!

活动入口>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP