我们利用Ca Erwin 生成erwin视图后,存在logical不能转成中文的问题,正常我们都logical是中文,physical是英文

利用python解决

所需工具下载:点击打开链接 https://download.csdn.net/my

安装python-2.7.13.msi 、python-2.7.13.msi 这两个python文件,安装后需要配置环境,跟java差不多(自行百度)

然后执行以下代码,以下代码转自robot_sql ,进行微调,在win10可用

  1. #!/usr/bin/python
  2. # -*- coding: UTF8-*-
  3. # robot_lei
  4. import win32com.client
  5. import re
  6. # 创建COM对象
  7. scapi = win32com.client.Dispatch('AllFusionERwin.SCAPI')
  8. # conn=win32com.client.Dispatch('ADODB.Connection')
  9. # 建立与持久装置中模型的连接
  10. # 源文件
  11. filename = "C:\\MGDB_MODEL.erwin"
  12. # 目标文件
  13. newfilename = "C:\\MGDB_MODEL1.erwin"
  14. scPUnit = scapi.PersistenceUnits.Add(filename, "RDO=yes")
  15. # 建立存取内存中模型数据的连接
  16. scSession = scapi.Sessions.Add()
  17. scSession.Open(scPUnit, 0, 0)
  18. # 事务控制
  19. scTranId = scSession.BeginTransaction()
  20. # 获取所有Entity模型对象
  21. scMObjects = scSession.ModelObjects.Collect(scSession.ModelObjects.Root, 'Entity', 1)
  22. for scObj in scMObjects:
  23. # 取Definition属性的值
  24. try:
  25. scDefineName = scObj.Properties('Definition').Value
  26. except Exception as ex:
  27. scDefineName = ''
  28. try:
  29. scName = scObj.Properties('Name').Value
  30. except Exception as ex:
  31. scName = ''
  32. # 对象名赋值
  33. # print "His scName is %s" % scName
  34. # print "His scDefineName is %s" % scDefineName
  35. scObj.Properties('Physical_Name').Value = scName
  36. scObj.Properties('Name').Value = scDefineName
  37. # 获取该Entity的所有Attribute对象
  38. scAttrObjects = scSession.ModelObjects.Collect(scObj, 'Attribute', 1)
  39. for scAttrObj in scAttrObjects:
  40. # scAttrDefineName = scAttrObj.Properties('Definition').Value
  41. # scAttrName = scAttrObj.Properties('Name').Value
  42. try:
  43. scAttrDefineName = scAttrObj.Properties('Definition').Value
  44. except Exception as ex:
  45. scAttrDefineName = ''
  46. try:
  47. scAttrName = scAttrObj.Properties('Name').Value
  48. except Exception as ex:
  49. scAttrName = ''
  50. # 对象名赋值
  51. scAttrObj.Properties('Physical_Name').Value = scAttrName
  52. # 注释可能带有括号之类的 这边做了特殊处理,不要处理的直接注释掉if代码即可
  53. if scAttrDefineName != '':
  54. scAttrDefineName = scAttrDefineName.replace('(', '(')
  55. is_find = re.findall(r'\(', scAttrDefineName)
  56. if is_find:
  57. scAttrDefineName = re.findall(r'(.*?)\(', scAttrDefineName)
  58. scAttrDefineName = scAttrDefineName[0]
  59. scAttrObj.Properties('Name').Value = scAttrDefineName
  60. scSession.CommitTransaction(scTranId)
  61. # 另存为一个新的文件
  62. scPUnit.Save(newfilename, 'OVF=yes')

最后生成后的效果为:

解决erwin逆向工程,logical不显示中文问题相关推荐

  1. Activiti保存.png 流程图片文件且解决idea中保存图片时显示中文乱码的解决方法

    Activiti保存.png 流程图片文件且解决idea中保存图片时显示中文乱码的解决方法 Eclipse 工具中的操作 流程图片生成的两种方式: 使用 activiti-designer 设计流程图 ...

  2. python中文显示不出来_彻底解决Python里matplotlib不显示中文的问题

    在很长一段时间里用Python绘图,matplotlib都不能很好的显示中文,起初是认为我的pycharm里的设置问题,但是发现同样的问题在spyder里也同样的出现了,虽然有的地方可以用英文实在不行 ...

  3. 解决windows系统下dos显示中文乱码

    1.进入dos ,输入chcp,查看当前支持的编码 2.输入命令:chcp 65001,在输入chcp的时候就显示目前支持的是utf-8 3.设置字体 4. 参考博客:点这里 转载于:https:// ...

  4. 服务器不能显示中文,彻底解决delphi WebBroker服务器中文乱码 delphi WebBroker服务器不能显示中文网页 WebBroker中文显示乱码...

    彻底解决delphi WebBroker服务器中文乱码 彻底解决WebBroker中文显示乱码 彻底解决delphi WebBroker服务器不能显示中文网页 这个问题被折腾惨啦! 网上一大堆,就没能 ...

  5. linux终端能显示中文,但是不能输入中文的解决方法

    linux终端能显示中文,但是不能输入中文的解决方法 linux终端能显示中文,但是不能输入中文的解决方法 第一种方法:修改用户目录下的.inputrc文件允许 8bit 输入即可 第二种方法(不建议 ...

  6. 网页显示中文乱码问题

    给遇到乱码问题的朋友,提供个思路吧,建议直接看后面的解决方法 遇到一个网页显示中文乱码的问题,特别奇怪,折腾了好久.被老大一番神操作给折服了,还能有这样的操作,666呀. 问题是这样的,我需要添加一个 ...

  7. php运行显示中文乱码,如何解决PHP界面显示中文乱码的问题

    如何解决PHP界面显示中文乱码的问题 发布时间:2020-07-14 15:19:00 来源:亿速云 阅读:74 作者:Leah 这期内容当中小编将会给大家带来有关如何解决PHP界面显示中文乱码的问题 ...

  8. 解决zabbix3.4图表显示中文乱码问题

    问题描述: 在Zabbix界面设置中,已经调成中文语言,可能zabbix自身携带的字体还不够完美,出现如下乱码: 测试环境: zabbix 3.4(经测试,目前3.x版本都适用) 解决步骤: 1. 寻 ...

  9. navicat for mysql 显示中文乱码解决办法

    navicat for mysql 显示中文乱码解决办法   最近遇到一个问题,用navicat for mysql 打开数据库时全都显示的是乱码(在用程序代码插入数据之前确保字符不是乱码),遇到问题 ...

最新文章

  1. 堆排序\链表实现局部排序
  2. Algorithms_入门基础_如何使用最高效的方式来判断一个数是否是2的N次方
  3. 机器视觉:图像与视频朝向检测
  4. oracle mssql交换数据库,Database link 连接oracle MSSql 实现逻辑数据互导
  5. Java生鲜电商平台-订单中心服务架构与异常订单逻辑
  6. 【C语言进阶深度学习记录】十八 条件编译的使用与分析
  7. python-虚拟环境的作用
  8. C++/C--内存的四驱模型
  9. mysql 参数 列 排序_将参数放入MySQL IN()后,按降序对列进行排序?
  10. oracle删除schema下所有对象,清空Schema中所有对象的步骤
  11. 南大周志华、俞扬、钱超最新力作:演化学习:理论与算法进展一书导读
  12. 20162327WJH程序设计与数据结构第七周总结
  13. 3月20 Bundle Adjustment光束平差法概述
  14. 联想拯救者u盘安装linux系统,联想拯救者Y7000系统盘重装如何设置U盘启动
  15. AVD Manager创建模拟器
  16. 团体程序设计天梯赛 -- 练习集 (L1合集)
  17. 纵观Tensorflow、Keras、Pytorch的发展史
  18. NLP文本生成的评价指标有什么?
  19. 数据分析——巧用ABtest,看杰伦和徐坤的流量之争
  20. Spring Boot项目的打包和解压

热门文章

  1. 大脑就是量子计算机,人类大脑就是台量子计算机
  2. uart串行口通信(一)
  3. 正则表达式 | 分类记忆法
  4. python:Non-ASCII character ‘\xe2′ in file
  5. 鸿蒙系统下载地址_华为鸿蒙2.0系统下载-鸿蒙系统(HarmonyOS)下载 github源码版-当快软件园...
  6. Dynamics 365Online 如何从APP Source中下载APP
  7. VulnHub-The Ether: EvilScience (v1.0.1)渗透学习
  8. 微信订水水站小程序开发有哪些作用
  9. 计算机的信息的表示教案,计算机中的信息表示 教案.doc
  10. 1319:星号阵列1