DA# 宏(6): DA# Modeler API
本文研究 DA# 宏中使用的 DA# Modeler API 对象模型、VBA 代码组合和源代码示例。
5.DA# 建模器 API
5.1. DA# Modeler API 对象模型
上一篇文章 (DA# 宏(1):DA#、DA# API、DA# 宏概述)简单介绍了DA# API对象模型。
DA# Modeler 提供的类列表如下。 (我使用 Excel VBE(Visual Basic 编辑器)中的“搜索对象”功能进行了检查。)
DA# Modeler API 的对象模型如下。 (官方手册上没有这个,我自己整理的。)
其中,最核心的从Application到Attribute的对象层次结构如下。
1)应用程序 -> 2)模型 -> 3)模型 -> 4)实体 -> 5)实体 -> 6)属性 -> 7)属性
如果将该层表示为DA# Modeler示例模型,则如下。
DA# Modeler API 的对象模型层次结构、概念和用法的简要总结如下。
5.2.在 Excel VBA 中使用 DA# Modeler API
Excel VBA 中的 DA# 建模器 API 提前绑定 要以这种方式使用它,您必须首先添加对“Modeler5”库的引用。
▼ 切换到Excel VBE(Visual Basic编辑器)(快捷键 Alt + F11) 执行工具 > 参考菜单。
▼ 在“Available References”列表中勾选并选择“Modeler5”,然后单击“OK”按钮。
现在您可以编写如下 VBA 代码:
'Modeler5 Application 개체 생성 Dim odApp As Modeler5.Application Set odApp = New Modeler5.Application '새 모델 개체 생성 Dim odModel As Modeler5.Model Set odModel = odApp.GetModelMustBe("새모델") 'Entity 생성과 값 할당 Dim odEntity As Modeler5.Entity Set odEntity = odModel.GetEntityMustBe("엔터티1") odEntity.TableName = "Table1" 'Attribute 생성과 값 할당 Dim odAttribute As Modeler5.Attribute Set odAttribute = odEntity.GetAttributeMustBe("속성1") odAttribute.ColName = "Column1"
5.3. DA#宏VBA代码配置
工作表、用户表单、模块、类列表和简要说明如下。
▼ 工作表对象
- shtAttributeGet:“Attribute(Get)”表单UI功能的实现
- shtAttributeSet:“属性(集)”表单UI功能的实现
- shtEntityGet:“Entity(Get)”表单UI功能的实现
- shtEntitySet:“Entity(Set)”表单UI功能的实现
- shtReverse:实现“反转”表单 UI 功能
▼ 表单对象
- frmModelFromFile:点击“选择模型(文件)”按钮时显示的用户表单
- frmProgress:处理函数时显示进度(ProgressBar)的用户表单
▼ 模块对象
- modDAConstType:函数实现所需的常量声明,实现DA# Enum和Name转换函数
- modDAModeler:DA#相关函数的实现(GetModel、Reverse、SetEntity、SetAttribute等)
- modTest:测试代码
- modUtil:常用函数(DoLog、ClearList、GetElapsedTime 等)
- modWinAPI:目前已弃用
▼ 类模块对象
- CDAAttribute:1 类属性单元
- CDAAttributeList:将属性列表作为字典结构(Key-Value)进行管理的类
- Key:ModelName:KeyName(KeyName为实体名.属性名或表名.列名格式)
- 值:CDAAttribute 实例
- CDAEntity:一类 1 单元实体
- CDAEntityList:将实体列表作为字典结构(Key-Value)进行管理的类
- Key: ModelName:KeyName (KeyName为实体名或表名)
- 值:CDAEntity 实例
- CDAFK:一类 FK 单位
- CDAFKList:将 FK 列表作为字典结构(Key-Value)进行管理的类
- Key: ModelName: 父实体名称 -> 子实体名称
- 值:CDAFK 实例
- CDAModel:一类模型单元
- CDAModelList:将模型列表作为字典结构(Key-Value)进行管理的类
- 关键:型号名称
- 值:CDAModel 实例
- CDASubject:学科领域一单元的类别
- CDASubjectList:以字典结构(键值)形式管理主题区域列表的类
- 键:模型名称:主题名称
- 值:CDASubject 实例
- CUDPNameType:管理UDP名称和目标的类(用于UDP获取/设置)
5.4.使用DA# API主类的源代码示例
5.4.1.从文件创建模型实例
作为模块“modDAModeler”中的函数“GetModel”实现。
'모델명과 파일명(경로포함)으로 Model Instance 반환 Public Function GetModel(ByRef adApp As Modeler5.Application, aModelName As String, aModelFileName As String) As Modeler5.Model Dim odModel As Modeler5.Model If adApp Is Nothing Then Set adApp = New Modeler5.Application Set odModel = adApp.GetModel(aModelName) '열려 있는 모델에서 ModelName으로 비교 If (odModel Is Nothing) And (Trim(aModelFileName) <> "") Then Set odModel = GetModelAlreadyOpened(adApp, aModelName, aModelFileName) '열려 있는 모델에서 FilePath로 비교 If odModel Is Nothing Then '모델이 열려 있지 않은 경우 adApp.OpenFile (aModelFileName) Set odModel = adApp.GetActiveModel End If End If adApp.SetActiveModel odModel Set GetModel = odModel If odModel Is Nothing Then '열려 있는 모델에도 없고 파일명도 비어있는 경우 MsgBox "GetModel Error" & vbLf & _ "ModelName: " & aModelName & vbLf & _ "ModelFileName: " & aModelFileName, vbOKOnly & vbExclamation, "GetModel Error" End If End Function
在调用 GetModel 函数之前,首先创建 Modeler5.Application 实例并将其作为参数传递,如下所示。
Set m_odApp = New Modeler5.Application Set odModel = GetModel(m_odApp, aFileNameOnly, aFileName)
如果未传递 Modeler5.Application 实例,则会在函数内部创建一个实例(第 4 行)。
5.4.2.从模型文件中获取实体列表
作为“Entity(Get)”表的“GetEntityListFromFile”函数实现。
Public Sub GetEntityListFromFile(aFileNameOnly As String, aFileName As String, baGetYN() As Boolean, _ aUDPNameCol As Collection, aIsSaveNClose As Boolean) Dim odModel As Modeler5.Model Dim odSubjects As Modeler5.Subjects, odSubject As Modeler5.Subject Dim odLogicalPane As Modeler5.Pane, odEntitys As Modeler5.Entitys, odEntity As Modeler5.Entity Dim sModelName As String, oBaseRange As Range, oOutRange As Range, oUDPOutRange As Range Dim vOutRngArr As Variant, vUDPRngArr As Variant Set odModel = GetModel(m_odApp, aFileNameOnly, aFileName) sModelName = odModel.Name If odModel Is Nothing Then MsgBox "DA# 모델이 없습니다." & vbLf & "<모델명: " & sModelName & ">", vbCritical GoTo Finalize_Section End If odModel.ActiveAction (False) 'Undo/Redo 해제 Set oBaseRange = Range("EntityListBase").Offset(1, 0): Set oOutRange = oBaseRange.Offset(m_lRowOffset, 0) Set oUDPOutRange = Range("EntityUDPNameBase").Offset(1, 0): Set oUDPOutRange = oUDPOutRange.Offset(m_lRowOffset, 0) Set odEntitys = odModel.Entitys Dim lEntIdx As Long ReDim vOutRngArr(1 To odEntitys.Count, DA_GETENT_ItemCount) ReDim vUDPRngArr(1 To odEntitys.Count, DA_GETENT_ItemCount) For lEntIdx = 1 To odEntitys.Count Set odEntity = odEntitys.Item(lEntIdx - 1) Dim arrayEnt() As Variant arrayEnt = odEntity.Values '엔터티 Property를 Variant Array로 한번에 받아오기 vOutRngArr(lEntIdx, DA_GETENT_Sequence_IDX) = lEntIdx vOutRngArr(lEntIdx, DA_GETENT_ModelName_IDX) = sModelName vOutRngArr(lEntIdx, DA_GETENT_EntityName_IDX) = odEntity.Name '- 엔터티 Property 직접 접근 방식 ----------------------------------------------------------------------------------------------------------------------------------------- If baGetYN(DA_GETENT_EntityTableName_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTableName_IDX) = odEntity.TableName If baGetYN(DA_GETENT_EntitySynonym_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntitySynonym_IDX) = odEntity.Synonym If baGetYN(DA_GETENT_EntityAltName_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityAltName_IDX) = odEntity.AltName If baGetYN(DA_GETENT_EntityDBOwner_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityDBOwner_IDX) = odEntity.DBOwner If baGetYN(DA_GETENT_EntityCategory_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityCategory_IDX) = GetEntityCategoryName(odEntity.Category) If baGetYN(DA_GETENT_EntityLevel_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityLevel_IDX) = odEntity.Level If baGetYN(DA_GETENT_EntityRank_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityRank_IDX) = GetEntityRankName(odEntity.Rank) If baGetYN(DA_GETENT_EntityVirtual_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityVirtual_IDX) = GetEntityTypeName(odEntity.Virtual) If baGetYN(DA_GETENT_EntityStandardType_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityStandardType_IDX) = GetStandardTypeName(odEntity.StandardType) If baGetYN(DA_GETENT_EntityStatus_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityStatus_IDX) = odEntity.Status If baGetYN(DA_GETENT_EntityPeriod_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityPeriod_IDX) = odEntity.Period If baGetYN(DA_GETENT_EntityMonthly_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityMonthly_IDX) = odEntity.Monthly If baGetYN(DA_GETENT_EntityManage_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityManage_IDX) = odEntity.Manage If baGetYN(DA_GETENT_EntityTotal_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTotal_IDX) = odEntity.Total If baGetYN(DA_GETENT_EntityDesc_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityDesc_IDX) = Replace(odEntity.Desc, vbCrLf, vbLf) '정의 If baGetYN(DA_GETENT_EntityFlow_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityFlow_IDX) = Replace(odEntity.Flow, vbCrLf, vbLf) '데이터 처리 형태 If baGetYN(DA_GETENT_EntityRemark_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityRemark_IDX) = Replace(odEntity.Remark, vbCrLf, vbLf) '특이사항 If baGetYN(DA_GETENT_EntityNote_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityNote_IDX) = Replace(odEntity.Note, vbCrLf, vbLf) '노트 If baGetYN(DA_GETENT_EntityTag_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTag_IDX) = odEntity.TagName '- 엔터티 Property Array 접근 방식 ----------------------------------------------------------------------------------------------------------------------------------------- ' If baGetYN(DA_GETENT_EntityTableName_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTableName_IDX) = arrayEnt(Modeler5.ENT_TABLENAME) ' If baGetYN(DA_GETENT_EntitySynonym_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntitySynonym_IDX) = arrayEnt(Modeler5.ENT_SYNONYM) ' If baGetYN(DA_GETENT_EntityAltName_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityAltName_IDX) = arrayEnt(Modeler5.ENT_ALTNAME) ' If baGetYN(DA_GETENT_EntityDBOwner_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityDBOwner_IDX) = arrayEnt(Modeler5.ENT_DBOWNER) ' If baGetYN(DA_GETENT_EntityCategory_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityCategory_IDX) = GetEntityCategoryName(arrayEnt(Modeler5.ENT_CATEGORY)) ' If baGetYN(DA_GETENT_EntityLevel_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityLevel_IDX) = arrayEnt(Modeler5.ENT_LEVEL) ' If baGetYN(DA_GETENT_EntityRank_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityRank_IDX) = GetEntityRankName(arrayEnt(Modeler5.ENT_RANK)) ' If baGetYN(DA_GETENT_EntityVirtual_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityVirtual_IDX) = GetEntityTypeName(arrayEnt(Modeler5.ENT_VIRTUAL)) ' If baGetYN(DA_GETENT_EntityStandardType_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityStandardType_IDX) = GetStandardTypeName(arrayEnt(Modeler5.ENT_STANDARDTYPE)) ' If baGetYN(DA_GETENT_EntityStatus_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityStatus_IDX) = arrayEnt(Modeler5.ENT_STATUS) ' If baGetYN(DA_GETENT_EntityPeriod_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityPeriod_IDX) = arrayEnt(Modeler5.ENT_PERIOD) ' If baGetYN(DA_GETENT_EntityMonthly_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityMonthly_IDX) = arrayEnt(Modeler5.ENT_MONTHLY) ' If baGetYN(DA_GETENT_EntityManage_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityManage_IDX) = arrayEnt(Modeler5.ENT_MANAGE) ' If baGetYN(DA_GETENT_EntityTotal_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTotal_IDX) = arrayEnt(Modeler5.ENT_TOTAL) ' If baGetYN(DA_GETENT_EntityDesc_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityDesc_IDX) = Replace(arrayEnt(Modeler5.ENT_DESC), vbCrLf, vbLf) '정의 ' If baGetYN(DA_GETENT_EntityFlow_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityFlow_IDX) = Replace(arrayEnt(Modeler5.ENT_FLOW), vbCrLf, vbLf) '데이터 처리 형태 ' If baGetYN(DA_GETENT_EntityRemark_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityRemark_IDX) = Replace(arrayEnt(Modeler5.ENT_REMARK), vbCrLf, vbLf) '특이사항 ' If baGetYN(DA_GETENT_EntityNote_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityNote_IDX) = Replace(arrayEnt(Modeler5.ENT_NOTE), vbCrLf, vbLf) '노트 ' If baGetYN(DA_GETENT_EntityTag_IDX) = True Then vOutRngArr(lEntIdx, DA_GETENT_EntityTag_IDX) = arrayEnt(Modeler5.ENT_TAGNAME) If Not aUDPNameCol Is Nothing Then 'Get UDP Value Dim oUDPNamePType As CUDPNameType, lUDPNameIdx As Long For lUDPNameIdx = 1 To aUDPNameCol.Count Set oUDPNamePType = aUDPNameCol(lUDPNameIdx) If oUDPNamePType.m_bUDPTargetYN = False Then GoTo SkipUDP vUDPRngArr(lEntIdx, lUDPNameIdx - 1) = odEntity.GetUDPValue(oUDPNamePType.m_sUDPName) SkipUDP: Next lUDPNameIdx End If '---------------------------------------------------------------------------------------------------- m_lRowOffset = m_lRowOffset + 1 Next lEntIdx '---------------------------------------------------------------------------------------------------- Set oOutRange = oOutRange.Resize(UBound(vOutRngArr, 1), UBound(vOutRngArr, 2)) Set oUDPOutRange = oUDPOutRange.Resize(UBound(vOutRngArr, 1), UBound(vOutRngArr, 2)) oOutRange.Value2 = vOutRngArr oUDPOutRange.Value2 = vUDPRngArr '---------------------------------------------------------------------------------------------------- Finalize_Section: odModel.ActiveAction (True) 'Undo/Redo 활성화 If aIsSaveNClose Then 'odApp.SaveActiveModelFile 'Get은 Save 하지 않도록 주석처리 m_odApp.CloseActiveModelFile End If Set odModel = Nothing Set odSubjects = Nothing Set odSubject = Nothing Set odEntity = Nothing End Sub
属性数组方式比实体属性直接方式有更好的性能,但是在写这篇文章的时候,存在访问数组时无法正确获取值的现象,所以又回到了直接方式。
第 88 至 91 行使用 Variant Array 将内存中的二维数组一次性写入 Excel 工作表。有关对此的解释,请参阅以下文章。
5.4.3.为实体设置值
作为“CDAEntityList”类的过程“SetValue”实现。
Public Sub SetValue(aTargetModelList As CDAModelList, aIsAppendMode As Boolean, _ baSetYN() As Boolean, aIsSaveNClose As Boolean) On Error GoTo ErrHandling Dim odApp As Modeler5.Application, odModel As Modeler5.Model Dim odEntitys As Modeler5.Entitys, odEntity As Modeler5.Entity Set odApp = New Modeler5.Application Dim startTime As Date, endTime As Date, sElapedTime As String DoLog ("Entity(Set) Started...") startTime = Now frmProgress.Hide: frmProgress.InitProgress: frmProgress.Show Application.ScreenUpdating = False Dim lTargetDAModelIndex As Long, oTargetDAModel As CDAModel Dim lEntIndex As Long, sKey As String, oDAEntity As CDAEntity, lSetCount As Long, sProgressMsg As String lSetCount = 0 For lTargetDAModelIndex = 0 To aTargetModelList.Count - 1 'Model Level Loop Set oTargetDAModel = aTargetModelList.GetItemByIndex(lTargetDAModelIndex) Set odModel = GetModel(odApp, oTargetDAModel.m_s모델명, oTargetDAModel.m_s모델파일명) odModel.ActiveAction (False) 'Undo/Redo 해제 frmProgress.UpdateProgressBar aTargetModelList.Count, lTargetDAModelIndex + 1, oTargetDAModel.m_s모델명, True sProgressMsg = "[" + CStr(lTargetDAModelIndex + 1) + "/" + CStr(aTargetModelList.Count) + "] " + oTargetDAModel.m_s모델명 DoDisplayStatusMsg sProgressMsg DoLog sProgressMsg + " (" + oTargetDAModel.m_s모델파일명 + ")" If frmProgress.IsCanceled Then GoTo Finalize_Section Set odEntitys = odModel.Entitys For lEntIndex = 0 To odEntitys.Count - 1 'Entity Level Loop Set odEntity = odEntitys.Item(lEntIndex) If m_eDACompareType = DACompareLogicalName Then sKey = odModel.Name + ":" + odEntity.Name ElseIf m_eDACompareType = DAComparePysicalName Then sKey = odModel.Name + ":" + odEntity.TableName End If Set oDAEntity = GetItem(sKey) If oDAEntity Is Nothing Then GoTo Skip_Set '변경할 대상이 아니면 skip lSetCount = lSetCount + 1 'Set 개수 증가 '- 엔터티 Property 직접 접근 방식 ----------------------------------------------------------------------------------------------------------------------------------------- ' If baSetYN(DA_SETENT_EntityName_IDX) = True Then odEntity.Name = oDAEntity.m_s엔터티명 ' If baSetYN(DA_SETENT_EntityTableName_IDX) = True Then odEntity.TableName = oDAEntity.m_s테이블명 ' If baSetYN(DA_SETENT_EntitySynonym_IDX) = True Then odEntity.Synonym = oDAEntity.m_s동의어 ' If baSetYN(DA_SETENT_EntityAltName_IDX) = True Then odEntity.AltName = oDAEntity.m_s보조명 ' If baSetYN(DA_SETENT_EntityDBOwner_IDX) = True Then odEntity.DBOwner = oDAEntity.m_sDBOwner ' If baSetYN(DA_SETENT_EntityCategory_IDX) = True Then odEntity.Category = GetEntityCategoryEnum(oDAEntity.m_s분류) ' If baSetYN(DA_SETENT_EntityLevel_IDX) = True Then odEntity.Level = oDAEntity.m_sLevel ' If baSetYN(DA_SETENT_EntityRank_IDX) = True Then odEntity.Rank = GetEntityRankEnum(oDAEntity.m_s단계) ' If baSetYN(DA_SETENT_EntityVirtual_IDX) = True Then odEntity.Virtual = GetEntityTypeEnum(oDAEntity.m_s유형) ' If baSetYN(DA_SETENT_EntityStandardType_IDX) = True Then odEntity.StandardType = GetStandardTypeEnum(oDAEntity.m_s표준화) ' If baSetYN(DA_SETENT_EntityStatus_IDX) = True Then odEntity.Status = oDAEntity.m_s상태 ' If baSetYN(DA_SETENT_EntityPeriod_IDX) = True Then odEntity.Period = oDAEntity.m_s발생주기 ' If baSetYN(DA_SETENT_EntityMonthly_IDX) = True Then odEntity.Monthly = oDAEntity.m_s월간발생량 ' If baSetYN(DA_SETENT_EntityManage_IDX) = True Then odEntity.Manage = oDAEntity.m_s보존기한 ' If baSetYN(DA_SETENT_EntityTotal_IDX) = True Then odEntity.Total = oDAEntity.m_s총건수 ' If baSetYN(DA_SETENT_EntityDesc_IDX) = True Then odEntity.Desc = IIf(aIsAppendMode, odEntity.Desc + vbCrLf + oDAEntity.m_s정의, oDAEntity.m_s정의) ' If baSetYN(DA_SETENT_EntityFlow_IDX) = True Then odEntity.Flow = IIf(aIsAppendMode, odEntity.Flow + vbCrLf + oDAEntity.m_s데이터처리형태, oDAEntity.m_s데이터처리형태) ' If baSetYN(DA_SETENT_EntityRemark_IDX) = True Then odEntity.Remark = IIf(aIsAppendMode, odEntity.Remark + vbCrLf + oDAEntity.m_s특이사항, oDAEntity.m_s특이사항) ' If baSetYN(DA_SETENT_EntityNote_IDX) = True Then odEntity.Note = IIf(aIsAppendMode, odEntity.Note + vbCrLf + oDAEntity.m_sNote, oDAEntity.m_sNote) ' If baSetYN(DA_SETENT_EntityTag_IDX) = True Then odEntity.TagName = oDAEntity.m_sTag Dim arrEnt(Modeler5.ENT_ARRAYCOUNT) As Variant '- 엔터티 Property Array 접근 방식 ----------------------------------------------------------------------------------------------------------------------------------------- If baSetYN(DA_SETENT_EntityName_IDX) = True Then odEntity.Name = oDAEntity.m_s엔터티명 If baSetYN(DA_SETENT_EntityTableName_IDX) = True Then arrEnt(Modeler5.ENT_TABLENAME) = oDAEntity.m_s테이블명 If baSetYN(DA_SETENT_EntitySynonym_IDX) = True Then arrEnt(Modeler5.ENT_SYNONYM) = oDAEntity.m_s동의어 If baSetYN(DA_SETENT_EntityAltName_IDX) = True Then arrEnt(Modeler5.ENT_ALTNAME) = oDAEntity.m_s보조명 If baSetYN(DA_SETENT_EntityDBOwner_IDX) = True Then arrEnt(Modeler5.ENT_DBOWNER) = oDAEntity.m_sDBOwner If baSetYN(DA_SETENT_EntityCategory_IDX) = True Then arrEnt(Modeler5.ENT_CATEGORY) = GetEntityCategoryEnum(oDAEntity.m_s분류) If baSetYN(DA_SETENT_EntityLevel_IDX) = True Then arrEnt(Modeler5.ENT_LEVEL) = oDAEntity.m_sLevel If baSetYN(DA_SETENT_EntityRank_IDX) = True Then arrEnt(Modeler5.ENT_RANK) = GetEntityRankEnum(oDAEntity.m_s단계) If baSetYN(DA_SETENT_EntityVirtual_IDX) = True Then arrEnt(Modeler5.ENT_VIRTUAL) = GetEntityTypeEnum(oDAEntity.m_s유형) If baSetYN(DA_SETENT_EntityStandardType_IDX) = True Then arrEnt(Modeler5.ENT_STANDARDTYPE) = GetStandardTypeEnum(oDAEntity.m_s표준화) If baSetYN(DA_SETENT_EntityStatus_IDX) = True Then arrEnt(Modeler5.ENT_STATUS) = oDAEntity.m_s상태 If baSetYN(DA_SETENT_EntityPeriod_IDX) = True Then arrEnt(Modeler5.ENT_PERIOD) = oDAEntity.m_s발생주기 If baSetYN(DA_SETENT_EntityMonthly_IDX) = True Then arrEnt(Modeler5.ENT_MONTHLY) = oDAEntity.m_s월간발생량 If baSetYN(DA_SETENT_EntityManage_IDX) = True Then arrEnt(Modeler5.ENT_MANAGE) = oDAEntity.m_s보존기한 If baSetYN(DA_SETENT_EntityTotal_IDX) = True Then arrEnt(Modeler5.ENT_TOTAL) = oDAEntity.m_s총건수 If baSetYN(DA_SETENT_EntityDesc_IDX) = True Then arrEnt(Modeler5.ENT_DESC) = IIf(aIsAppendMode, odEntity.Desc + vbCrLf + oDAEntity.m_s정의, oDAEntity.m_s정의) If baSetYN(DA_SETENT_EntityFlow_IDX) = True Then arrEnt(Modeler5.ENT_FLOW) = IIf(aIsAppendMode, odEntity.Flow + vbCrLf + oDAEntity.m_s데이터처리형태, oDAEntity.m_s데이터처리형태) If baSetYN(DA_SETENT_EntityRemark_IDX) = True Then arrEnt(Modeler5.ENT_REMARK) = IIf(aIsAppendMode, odEntity.Remark + vbCrLf + oDAEntity.m_s특이사항, oDAEntity.m_s특이사항) If baSetYN(DA_SETENT_EntityNote_IDX) = True Then arrEnt(Modeler5.ENT_NOTE) = IIf(aIsAppendMode, odEntity.Note + vbCrLf + oDAEntity.m_sNote, oDAEntity.m_sNote) If baSetYN(DA_SETENT_EntityTag_IDX) = True Then arrEnt(Modeler5.ENT_TAGNAME) = oDAEntity.m_sTag odEntity.Values = arrEnt '-------------------- Set UDP Value -------------------- If oDAEntity.m_oUDPDic.Count = 0 Then GoTo Skip_Set 'UDP Collection이 비어 있으면 Skip Dim vUDPName As Variant, sUDPValue As String For Each vUDPName In oDAEntity.m_oUDPDic.Keys 'Dictionary에는 Set대상 UDP만 가지고 있음 sUDPValue = oDAEntity.m_oUDPDic(vUDPName) odEntity.SetUDPValue vUDPName, sUDPValue Next vUDPName Skip_Set: odEntity.UpdateDrawEntity Next lEntIndex odModel.ActiveAction (True) 'Undo/Redo 활성화 If aIsSaveNClose Then odApp.SaveActiveModelFile odApp.CloseActiveModelFile End If Next lTargetDAModelIndex frmProgress.UpdateProgressBar aTargetModelList.Count, lTargetDAModelIndex + 1, oTargetDAModel.m_s모델명, True ErrHandling: Resume Next Finalize_Section: Application.ScreenUpdating = True endTime = Now sElapedTime = GetElapsedTime(startTime, endTime) DoLog ("Entity(Set) Finished. [ElapsedTime: " + sElapedTime + "]") frmProgress.SetDoneMsg sProgressMsg, sElapedTime MsgBox "처리완료" + vbCrLf + _ "처리건수: " + CStr(lSetCount) + vbCrLf + _ "Elapsed Time: " + sElapedTime, vbInformation End Sub
- 第 21 行:撤消/重做。 (节省内存并提高性能)
- 第10、25、112行:用DoLog函数记录处理状态。 (该函数是使用Windows API 'OutputDebugMessage'的用户函数,这方面将单独发布)
- 第83行:通过将包含实体属性的Array(Variant类型)分配给Entity.Values来一次性设置值。
到目前为止,我们已经了解了 DA# 宏中使用的 DA# Modeler API 对象模型、VBA 代码配置和源代码示例。
对于源代码来说,我在3年多的时间里时不时地重复编码和重构,所以整体代码一致性不是很好。整体重构应该在某个时候触及,但我不知道什么时候。
我们希望该工具对使用 DA# 的数据建模者和 DA(数据架构师)有所帮助。
<< 相关文章列表 >>