kaluluosi / GDExcelExporter

为Godot开发的excel表导出工具
https://kaluluosi.github.io/GDExcelExporter/
MIT License
38 stars 4 forks source link
database datatable godot toolkit

GD-ExcelExporter

Build Code Coverage Test

English

GDExcelExpoter 是为Godot设计的Excel表格导出数据资源的工具。 它内置了好几种数据表导出和读取方案(导出器),支持Godot3.x、Godot4.x。

下面我们用ee代指GDExcelExporter

在线文档

更新日志

3.0版本

  1. 重构框架,类型转换器、导出器、引擎全部面向接口编程,而且都entry_points插件化,以后可以自己写插件自定义。
  2. 默认采用xlrd读取excel,以此支持linux、macos、windows全平台的导出,而且速度更快。用户仍然可以选择用xlwings作为excel读取库(由xlrd其实已经不需要了)。
  3. 修改多语言字段类型,原本是#开头,比如#string,现在改为tr_string
  4. 包改名为gd_excelexporter,因为之前包名gd-excelexportersrc\excelexporter不一致,整出很多麻烦,现在统一了。因此你需要卸载原来的gd-excelexporter包,重新安装这个包。
  5. 其他的没有任何改变,兼容原来的settings项目目录。但是安全起见建议重新ee init一个目录,然后将data下的表迁移过去重新导出。

为什么需要这个工具?

Unreal引擎中有一个工具叫做DataTable,它的作用是充当一个小型的数据库给游戏设计人员编辑配置数值数据。

打个比方,我们游戏中有道具系统,而道具整个对象一旦属性字段建模好,那么就可以通过配置这些属性定义出各种各样的道具。

而这些数据在没有DataTable的时候我们要么在脚本代码里用一个字典写,要么在Json文件里写,维护十分麻烦。数据库(即便是sqlite)又太过重量级,同时数据库十分不利于编辑和测试,数据库的读取接口也十分繁琐不够直接。

因此Unreal引擎的解决办法是在引擎内部开发了个轻量级文件数据库-DataTable,我们可以把海量的数据条目填写在各种DataTable中,然后程序员可以直接的访问这些DataTable读取里面的数据。

然而,中国游戏开发人员更懂得折中。因为我们的Office Excel表格工具本质上讲就是一个轻量级文件数据库,并且作为生产力工具发展这么多年,强大的数据处理能力,支持vbs脚本扩展,非常适合充当数据管理工具。

因此就有了用Excel表格来作为DataTable的做法。

GDExcelExporter只是个搬运工,他把按照他的规格设计的表格读取转换生成游戏引擎里能够直接读取的数据文件。

有了这个工具:

  1. 就不用手写json
  2. 也不用嵌入sqlite
  3. 由于数据是以项目的文件资源存在,因此也是版本管理工具友好的
  4. 也因为数据是文件资源,因此热更新友好
  5. 你不需要学习别的工具去编辑维护数据,会用excel就可以,你可以用上你excel中所有的技巧去编辑数据

快速上手

系统要求

Python:^3.8.1

Platform: Windows、Mac、Linux

[!WARNING]

Excel引擎xlwings只支持Windows平台,建议默认使用xlrd引擎,导出更快兼容全平台。

Godot版本:^3.4

安装

通过pip (建议)

pip install gd_excelexporter

或者直接去右边release里下载已经打包好的可执行文件(ee.exe,你需要将这个exe加到环境变量)。

创建配置表项目

打开你的Godot游戏项目,项目根目录下右键打开命令行(此处打开powershell) 图 1
图 2
图 3
图 4

尝试配置并导出你第一份数据文件

图 5

在游戏中读取

首先你需要将Setting\dist\settings.gd添加到项目autoload

图 6
图 7

通过查看settings.gd你就知道这个文件是用来统一管理数据源的。这样你就不需要每次想读取数据的时候又要加载数据和解析。

图 8

然后你就可以像下面一样读取数据

图 9

图 10

表格规范

由于篇幅有限,我无法一一讲解所有的细节。所以剩下的希望您自己去探索。 ee对表格的格式有严格要求,因此我给您留了个sample文件夹,里面有个示例.xlsx模板。 当您要建立新表格的时候可以拷贝这个模板去建立。 sample目录下的示例.xlsx表格里已经把ee能支持的所有字段类型都演示了一遍,自行参考。

导出路径

ee将excel文件当作文件夹,其中sheet才是数据表,因此导出的时候是 示例\demo.gd这样存放。

忽略符号

sheet名如果以~开头,ee会忽略不导出。 字段名如果以*开头,ee也会忽略不导出。

这样你可以在表格里留一些注释用的内容。

特性

GDExcelExporter支持将Excel表导出成几种不同格式的数据文件。 每种格式数据文件在特性、性能和使用上有所差异。 篇幅有限,快速开始只演示了GDS2.0导出器导出来的数据文件和用法。 其他的导出器需要您自己去尝试。

导出器方案

导出器ID 导出器名称 Godot 3.x Godot 4.x C# 支持代码配置
GDS1.0 GodotScript 1.0 支持
GDS2.0 GodotScript 2.0 支持
RESOURCE Resource 不支持
JSON1.0 Json 不支持
JSON2.0 Json 不支持
C# CSharp 未开发 未开发 未开发 未开发

下面一一介绍这些导出器区别

GDS1.0 和 GDS2.0

这两个导出器是将Excel表格导出成GodotScript脚本类,这个类有个data字典变量,该变量里写满了表格里的数据。

如下所示

# GDS1.0
extends Reference
var None = null
var False = false
var True = true

var data = \
{1: {'array': [1, 2, 3, 4, 5], 'array_bool': [True, False], 'function': funcref(self,'function_1')...

static func function_1(args=[]):
    print(args)
# GDS2.0
extends RefCounted
var None = null
var False = false
var True = true

var data = \
{1: {'array': [1, 2, 3, 4, 5], 'array_bool': [True, False], 'function': Callable(self,'function_1')...

static func function_1(args=[]):
    print(args)

用GodotScript作为数据源的优点:

  1. GodotScript脚本除了是源码外,它也是游戏资源,因此直接将数据写到脚本里当数据源可以省略读文件再解析这一步。
  2. 由于是GodotScripte脚本,因此编辑器也会发现其语法错误,也会在运行时准确发现数据的错误。
  3. GodotScript脚本的加载速度十分的快,比用FileAccess打开要快很多倍。
  4. 用于是脚本,因此Excel表中可以配置代码,如上面例子。

GDS1.0和GDS2.0导出器区别不是很大,主要是GodotScript1.0和GodotScript2.0里 Reference和Funcref两个类改名成了RefCounted和Callable,因此分开实现了两个导出器。

RESOURCE

这个导出器是以Godot Resource文件作为数据源。

[gd_resource type="Resource" script_class="EEDataTable" load_steps=2 format=3]

[ext_resource type="Script" path="res://Setting/dist/ee_data_table.gd" id="1"]

[resource]
script = ExtResource("1")
data = {1: {"array": [1, 2, 3, 4, 5], "array_bool": [true, false], ...

跟GDS的方案来讲没有什么优势,不支持配置代码,读取效率也很慢。

JSON1.0 和 JSON2.0

用json文本文件作为数据源,跟其他方案比起来,其他方案因为是Godot的资源,因此读和解析是Godot一条龙处理的,而json文本就需要settings.gd里写方法去读和解析。

json方案并没有什么优点,唯一的优点就是json文件打开来后是人类友好的,比较容易阅读的,其他格式都全生成到一行里了基本无法阅读。

{
  "1": {
    "id": 1,
    "int": 1,
    "float ": 1.0,
    "string": "恭喜你!成功配置好了Godot导表项目。",
    "bool": true,
    "array": [
      1,
      2,
      3,
      4,
      5
    ],
    "array_str": [
      "a",
      "b",
      "c"
    ],
    "array_bool": [
      true,
      false
    ],
    "dict": {
      "name": "Tom",
      "age": 10
    },
    "function": "print(args)"
  },...

由于Godot4.0文件读写和JSON的接口发生变动,导致需要两个JSON导出器来分别对应Godot3.x和Godot4.x。

专用辅助插件

由于每次导表都要到settings目录下操作太麻烦了,因此特地开发一个Godot插件,让我们可以直接在Godot编辑器中点击一个按钮进行导表。

Godot插件-GDExcelExporter-Plugin

最后

希望这个工具能够给一些独立游戏人或者业余自娱自乐的人一些帮助。 如果你用上了我的工具,有什么问题最好直接提issue。

如果你在你的独立游戏项目中使用了我的工具,如果能够在游戏结尾员工名单或者开源证书页面中特别鸣谢加上我的名字,让我也占个光,谢谢(非强制,请随意)。

Snipaste_2024-04-19_17-01-18

联系方式

QQ群:118258918 Snipaste_2024-04-19_06-50-25