【VBA】代码生成工具——将Excel配置表转成脚本与配置文件(含源码)

在软件开发中多采用自动生成工具,将配置表生成对应的脚本文件(如.lua)和读取脚本的配置文件(如.h与cpp),所有配置文件由管理器ConfigMgr统一加载入内存,程序运行时在需要的地方,即可直接从内存中查询

自动生成工具

将Excel表格转成.lua文件

Private Sub CommandButton1_Click()
    Dim fso, MyFile, txt, content1, content2, content3
    Dim rows, columns
    Dim firstID, cell_title, cell_value
    'Set fso = CreateObject("Scripting.FileSystemObject")
    'Set MyFile = fso.CreateTextFile(Split(ThisWorkbook.Path, "\²ß»®")(0) & "\Data_" & Split(ThisWorkbook.Name, ".")(0) & ".lua", True, True)
    Dim filename
    filename = Split(ThisWorkbook.Path, "\²ß»®")(0) & "\Data_" & Split(ThisWorkbook.Name, ".")(0) & ".lua"
    
    Set fso = CreateObject("adodb.stream")
    fso.Type = 2
    fso.Mode = 3
    fso.Charset = "UTF-8"
    fso.Open
   ......
    '创建文本内容
    txt = "--[[" & Chr(13) & _
    "From: " & Split(ThisWorkbook.Name, ".")(0) & ".xlsx" & Chr(13) & _
    "]]" & Chr(13) & _
    "_G._G = _G or {};" & Chr(13) & _
    "_G._G.Data_" & Split(ThisWorkbook.Name, ".")(0) & "={" & Chr(13) & _
    content1 & _
    "}"  
   ......
Call Utf8WithoutBom(filename & ".temp", filename) Kill filename & ".temp" MsgBox "转换完成"End Sub

将Excel表格转成配置文件

Private Sub CommandButton2_Click()

 Dim tabname, classname
    Dim hfso, hFile, hStream, hTextStream, htxt, hcontent1, hcontentTab, hcontentClass, hcontentLine, hcontentData, hcontentData1, hcontentDataLine, hEditContent(2)
    Dim cppfso, cppFile, cppStream, cppTextStream, cpptxt, cppcontent1, cppcontent, cppcontentLine, cppFunction, cppEditContent
    Dim columns, isneedbuf, ishaslst
    Dim valuename, valuetype, keyname
    Dim hFileName, cppFileName
    Dim isCreate
    Dim Check, rows
    Set Check = CreateObject("scripting.dictionary")   
   ......
If IsEmpty(hFileName) Or IsEmpty(cppFileName) Then MsgBox "Ó¦¸ÃÑ¡ÔñÒ»¸ö.hºÍÒ»¸ö.cppÎļþ" End End If Set hfso = CreateObject("Scripting.FileSystemObject") Set cppfso = CreateObject("Scripting.FileSystemObject")
   ......
Function CharToBig(charS As String) As String If Asc(charS) >= 97 And Asc(charS) <= 122 Then CharToBig = Chr(Asc(charS) - 32) Else CharToBig = charS End IfEnd Function

配置文件管理器(统一加载数据至内存)

#define CFG_CREATE(x)	x::GetSingleton().Destory();\
 	if (false == x::GetSingleton().Create()) {\
 		LoLogs::WriteLog("%s create failed!\n", #x);\
 		return false; \
	 	}

bool	CConfigMgr::Create()
{
	CFG_CREATE(CGlobalCfg);
	CFG_CREATE(CActorTime);
	CFG_CREATE(CActorAnimTimeCfg);
	CFG_CREATE(CBulletCfg);

	// 场景配置表
	CFG_CREATE(CSceneCfg);
	CFG_CREATE(CSceneBoxCfg);
	CFG_CREATE(CAiCfg);
	CFG_CREATE(CLevelupCfg);

	CFG_CREATE(CActorBoxCfg);
	CFG_CREATE(CActorBasicCfg);
	CFG_CREATE(CActorStateCfg);
	CFG_CREATE(CActorStrikeCfg);

	//CFG_CREATE(CAnimationCfg);

	CFG_CREATE(CBuffCfg);
	CFG_CREATE(CBuffTriggerCfg);
	CFG_CREATE(CSkillAnimTimeCfg);
	CFG_CREATE(CSkillStoneCfg);

	CFG_CREATE(CInitPlayerCfg);

	CFG_CREATE(CTalentCfg);
	CFG_CREATE(CTaskCfg);
	CFG_CREATE(CTaskActiveCfg);
	CFG_CREATE(CDungeonCfg);
	CFG_CREATE(CStageAwardsCfg);
	CFG_CREATE(CResStageCfg);

	CFG_CREATE(CSignCfg);

	return true;
}
bool	CConfigMgr::Destory()
{
	return true;
}

代码生成工具——将Excel配置表转成脚本与配置文件(含源码)



  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值