免费注册 查看新帖 |

Chinaunix

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

sed在多行替换中的应用[原创]  关闭 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-03-12 16:53 |只看该作者 |倒序浏览
在EC程序移植过程中,令人头痛的是数据库存储结构的不同造成程序的大量改动。
比如,在原始程序的有很多与如下类似的建表语句:
  1. EXEC SQL CREATE RAW TABLE aaaaa
  2. {
  3. a        char(2)
  4. }
  5. FRAGMENT BY ROUND ROBIN
  6.     IN workdbs1, workdbs2, workdbs3, workdbs4, workdbs5, workdbs6,
  7.        workdbs7, workdbs8;
复制代码

在新的系统中数据库并没有这样的dbs分配,要改造程序的话,需要将
  1. FRAGMENT BY ROUND ROBIN
  2.     IN workdbs1, workdbs2, workdbs3, workdbs4, workdbs5, workdbs6,
  3.        workdbs7, workdbs8
复制代码

部分删除。

一一由手工删除,不仅繁琐,还易遗漏,出错。
我参照《sed&awk》 编写如下程序来解决此问题:
  1. #!/bin/ksh
  2. #transfer -- found the serial "FRANGMENT.*;" and delete it
  3. #parameter: filenames

  4. for file
  5. do
  6. sed '
  7. :begin
  8. /FRAGMENT .*;/{
  9. s//;/
  10. b begin
  11. }
  12. /FRAGMENT .*/{
  13. N
  14. s/FRAGMENT [^;]*\n.*;/;/
  15. t again
  16. b begin
  17. }
  18. :again
  19. P
  20. D' $file
  21. done
复制代码

论坛徽章:
7
荣誉版主
日期:2011-11-23 16:44:17子鼠
日期:2014-07-24 15:38:07狮子座
日期:2014-07-24 11:00:54巨蟹座
日期:2014-07-21 19:03:10双子座
日期:2014-05-22 12:00:09卯兔
日期:2014-05-08 19:43:17卯兔
日期:2014-08-22 13:39:09
2 [报告]
发表于 2004-03-13 01:06 |只看该作者

sed在多行替换中的应用[原创]

用sed修改类似c这样不以换行作为语句分割的计算机语言,有一定的风险。由于程序书写风格的多样化,很难做到万无一失的替换。仅举2例:
我对楼主所涉及的程序语言不熟,以c作为例子(大多数语言都有字符常量和注释语句)
1.引号中的字符
  1. printf("FRAGMENT :%s,%s",...);
复制代码

2.注释
  1. //FRAGMENT start...
  2. EXEC SQL CREATE RAW TABLE aaaaa
  3. {
  4. a   char(2)
  5. }
复制代码

下面是我的一些测试,其中未考虑以上两种情况,只能对较为正常的书写风格有效,如果大家有更变态的程序书写格式,欢迎测试^_^
  1. r2007@www r2007 $ cat a
  2. EXEC SQL CREATE RAW TABLE aaaaa
  3. {
  4. a   char(2)
  5. XFRAGMENT char(30)
  6. }FRAGMENT ... ...; FRAGMENT ... ...;TEST; FRAGMENT ... ...;
  7. FRAGMENT BY ROUND ROBIN
  8.     IN workdbs1, workdbs2, workdbs3, workdbs4, workdbs5, workdbs6,
  9.        workdbs7, workdbs8;
  10. r2007@www r2007 $ sed ':b;/\<FRAGMENT\>/{:a;s/\<FRAGMENT\>[^;]*;/;/;tb;N;ba;}' a  
  11. EXEC SQL CREATE RAW TABLE aaaaa
  12. {
  13. a   char(2)
  14. XFRAGMENT char(30)
  15. }; ;TEST; ;
  16. ;
复制代码

论坛徽章:
0
3 [报告]
发表于 2004-03-15 08:46 |只看该作者

sed在多行替换中的应用[原创]

谢谢关注,FRAGMENT是程序中的关键字,就我所在的这个系统,还没有类似的情况发生。它表明数据库的分片策略。正是考虑到书写的多样性,比如
这样的写法:
FRAGMENT BY ROUND ROBIN    IN workdbs1,
workdbs2, workdbs3, workdbs6, workdbs7, workdbs8;

换行的位置不一样。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP