通过ERWIN API 实现中文注释(Definition)批量替换成Attributes
来源:互联网 发布:己知线段AB=12,CD=6 编辑:程序博客网 时间:2024/06/16 18:00
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 -*-import win32com.client# 创建COM对象scapi = win32com.client.Dispatch('AllFusionERwin.SCAPI')# conn=win32com.client.Dispatch('ADODB.Connection')# 建立与持久装置中模型的连接# 源文件filename = "C:\\111.erwin"# 目标文件newfilename = "C:\\122.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, ex: scDefineName = '' try: scName = scObj.Properties('Name').Value except Exception, 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, ex: scAttrDefineName = '' try: scAttrName = scAttrObj.Properties('Name').Value except Exception, ex: scAttrName = ''# 对象名赋值 scAttrObj.Properties('Physical_Name').Value = scAttrName scAttrObj.Properties('Name').Value = scAttrDefineNamescSession.CommitTransaction(scTranId)# 另存为一个新的文件scPUnit.Save(newfilename, 'OVF=yes')上述软件安装完之后直接在你的电脑上执行即可,最后会得到下图效果(已经全部批量改过来了,python就是如此强大)
阅读全文
0 0
- 通过ERWIN API 实现中文注释(Definition)批量替换成Attributes
- Dreamweaver 批量替换注释
- 批量 // 注释替换为 /*的注释
- ERWIN加注释
- Erwin 字段加注释
- python 单行注释 多行注释 批量注释 中文注释
- [weka]Ignore Attributes通过代码实现
- ERWIN导出SQL 附带注释
- linux批量替换文件中文本内容
- vi中如何实现批量替换?
- Vim实现批量注释的方法
- Vim实现批量注释的方法
- Vim实现批量注释的方法
- Vim实现批量注释的方法
- Vim实现批量注释的方法
- Vim实现批量注释的方法
- python如何实现批量注释print
- 通过Erwin的反向工程导入实体
- Python: 你不知道的 super
- 线下活动【北京】敏捷开发:产品与项目管理实践讲座(免费)
- 新手理解Navigator的教程
- iOS 上下滑动tableView导航透明度逐渐改变
- 哇塞,优惠活动还在持续呀~
- 通过ERWIN API 实现中文注释(Definition)批量替换成Attributes
- @RunWith (SpringJUnit4ClassRunner.class) error
- shell脚本判断容器容量(学习笔记二)
- 统一设备模型(五):kobj、kset分析
- StanFord University CS131 lecture2:Linear Algebra Primer
- SpringMVC初探,HelloWorld及基础配置.
- mysql 5.7以上版本安装配置方法图文教程
- Spring3:AOP
- 申论高分作者心得分享——站在政府的角度写申论