diff --git a/README.md b/README.md index def1d6ad3b6a8b3664650f2d76445da0c83560fe..4360d8007f400c04198b0ab229d45a7b6b680259 100644 --- a/README.md +++ b/README.md @@ -1,3 +1,147 @@ # skill_tree_oo -面向对象程序设计技能树 +`面向对象程序设计技能树` 是[技能森林](https://gitcode.net/csdn/skill_tree)的一部分。 + +## 目录结构说明 + +* 技能树`骨架文件`: + * 位置:`data/tree.json` + * 说明:该文件是执行 `python main.py` 生成的,请勿人工编辑 +* 技能树`根节点`配置文件: + * 位置:`data/config.json` + * 说明:可编辑配置关键词等字段,其中 `node_id` 字段是生成的,请勿编辑 +* 技能树`难度节点`: + * 位置:`data/xxx`,例如: `data/1.面向对象程序设计初阶` + * 说明: + * 每个技能树有 3 个等级,目录前的序号是必要的,用来保持文件夹目录的顺序 + * 每个目录下有一个 `config.json` 可配置关键词信息,其中 `node_id` 字段是生成的,请勿编辑 +* 技能树`章节点`: + * 位置:`data/xxx/xxx`,例如:`data/1.面向对象程序设计初阶/1.面向对象程序设计基础` + * 说明: + * 每个技能树的每个难度等级有 n 个章节,目录前的序号是必要的,用来保持文件夹目录的顺序 + * 每个目录下有一个 `config.json` 可配置关键词信息,其中 `node_id` 字段是生成的,请勿编辑 +* 技能树`知识节点`: + * 位置:`data/xxx/xxx/xxx`,例如:`data/1.面向对象程序设计初阶/1.面向对象程序设计基础/1.HelloOO` + * 说明: + * 每个技能树的每章有 `n` 个知识节点,目录前的序号是必要的,用来保持文件夹目录的顺序 + * 每个目录下有一个 `config.json` + * 其中 `node_id` 字段是生成的,请勿编辑 + * 其中 `keywords` 可配置关键字字段 + * 其中 `children` 可配置该`知识节点`下的子树结构信息,参考后面描述 + * 其中 `export` 可配置该`知识节点`下的导出习题信息,参考后面描述 + +## `知识节点` 子树信息结构 + +例如 `data/1.面向对象程序设计初阶/1.面向对象程序设计基础/1.HelloOO/config.json` 里配置对该知识节点子树信息结构: + +```json +{ + // ... + + "children": [ + // TODO ... + ], +} +``` + +## `知识节点` 的导出习题编辑 + +例如 `data/1.面向对象程序设计初阶/1.面向对象程序设计基础/1.HelloOO/config.json` 里配置对该知识节点导出的习题 + +```json +{ + // ... + "export": [ + "helloworld.json" + ] +} +``` + +在 export 字段中,我们列出习题定义 json ,下面我们了解如何编写习题。 + +## `知识节点` 的导出习题选项配置编辑 + +目前我们支持使用 markdown 语法直接编辑习题和各选项。 + +如前文内容,我们在知识节点下增加习题 `helloworld`的定义文件,即在`data/1.面向对象程序设计初阶/1.面向对象程序设计基础/1.HelloOO` 目录增加一个`helloworld.json`文件: + +```json +{ + "type": "code_options", + "author": "xxx", + "source": "helloworld.md", + "notebook_enable": false +} +``` + +其中 type 字段目前都固定是 `code_options`,`notebook_enable` 字段决定这个习题是否生成对应的 `notebook` ,可以默认设置为false。根据具体情况写好其它字段,注意这里 `source` 的文件名,我们指定了一个 markdwon 文件。现在我们新建一个 `helloworld.md` 并编辑为: + +````markdown +# Hello OO + +以下哪个是面向对象程序代码 + +## 答案 + +```cpp +// C++ +class Object{ + Object(){} + ~Object(){} + void test(){ + std::cout<<"hello"<