通过ERWIN API 实现中文注释(Definition)批量替换成Attributes

     erwin可以通过反导向的方法直接将ORACLE的建表语句直接变成模型,但是在生成过程中逻辑模型的字段会是建表语句的字段,也就是会是英文名,如何将英文名改成中文名是一个特别头疼的问题,一个一个去更新太慢太麻烦(尤其是对我这么懒得人),网上找到了ERWIN的API接口可以通过Python来直接调用实现,怀着激动的心情立马找了找ERWIN的API文档,回归正题:

一、工具准备

1)、在你的erwin安装目录下找到ERwin_API_Ref.pdf,文档详细介绍了ERWIN的API功能和属性。

2)、下载python_2.7.13150.msi(32位),下载pywin32-218.win32-py2.7.exe(也就是COM的接口包),以上工具网上搜索即可见。

3)、下载ERWIN7.3.10版本安装并且破解注册。

可以看到我下面的模型逻辑模型下全是英文(前两个是手改的)

二、编写Python代码,实现批量更改

环境是Windows7系统下,代码如下

#!/usr/bin/python
# -*- coding: cp936 -*-
# robot_lei
import win32com.client
import re


# 创建COM对象
scapi = win32com.client.Dispatch('AllFusionERwin.SCAPI')
# conn=win32com.client.Dispatch('ADODB.Connection')
# 建立与持久装置中模型的连接
# 源文件
filename = "C:\\MGDB_MODEL.erwin"
# 目标文件
newfilename = "C:\\MGDB_MODEL1.erwin"
scPUnit = scapi.PersistenceUnits.Add(filename, "RDO=yes")
# 建立存取内存中模型数据的连接
scSession = scapi.Sessions.Add()
scSession.Open(scPUnit, 0, 0)
# 事务控制
scTranId = scSession.BeginTransaction()
# 获取所有Entity模型对象
scMObjects = scSession.ModelObjects.Collect(scSession.ModelObjects.Root, 'Entity', 1)
for scObj in scMObjects:
    # 取Definition属性的值
    try:
        scDefineName = scObj.Properties('Definition').Value
    except Exception as ex:
        scDefineName = ''
    try:
        scName = scObj.Properties('Name').Value
    except Exception as ex:
        scName = ''
    # 对象名赋值
    # print "His scName is %s" % scName
    # print "His scDefineName is %s" % scDefineName
    scObj.Properties('Physical_Name').Value = scName
    scObj.Properties('Name').Value = scDefineName
    # 获取该Entity的所有Attribute对象
    scAttrObjects = scSession.ModelObjects.Collect(scObj, 'Attribute', 1)
    for scAttrObj in scAttrObjects:
        # scAttrDefineName = scAttrObj.Properties('Definition').Value
        # scAttrName = scAttrObj.Properties('Name').Value
        try:
            scAttrDefineName = scAttrObj.Properties('Definition').Value
        except Exception as ex:
            scAttrDefineName = ''
        try:
            scAttrName = scAttrObj.Properties('Name').Value
        except Exception as ex:
            scAttrName = ''
        # 对象名赋值
        scAttrObj.Properties('Physical_Name').Value = scAttrName
        # 注释可能带有括号之类的 这边做了特殊处理,不要处理的直接注释掉if代码即可
        if scAttrDefineName != '':
            scAttrDefineName = scAttrDefineName.replace('(', '(')
            is_find = re.findall(r'\(', scAttrDefineName)
            if is_find:
                scAttrDefineName = re.findall(r'(.*?)\(', scAttrDefineName)
                scAttrDefineName = scAttrDefineName[0]
        scAttrObj.Properties('Name').Value = scAttrDefineName
scSession.CommitTransaction(scTranId)
# 另存为一个新的文件
scPUnit.Save(newfilename, 'OVF=yes')

上述软件安装完之后直接在你的电脑上执行即可,最后会得到下图效果(已经全部批量改过来了,python就是如此强大)



  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值