嘿,大家好呀,我是景淮,一个加拿大的程序员,沉迷 AI 不能自拔中。
今天的灵感来自于 月影 的 Learn Chinese Character 。
GPTs 链接:https://chat.openai.com/g/g-HhhuZ8uIY-learn-chinese-character
通过调用 API 可以把汉字的每一个笔画进行展示,然后清晰的显示出来。
同样是汉字学习,想把孩子查字典的过程一起融入进去,辅助孩子进行查字典的练习。这篇内容本来是想写在孩子王系列内容中的,但是在找方法论中,与 顾家文老师 和 蕾蕾老师 (感谢 MQ 老师引荐~)学习了一下现在孩子们们是怎么使用词典的,同时会有什么样的困境。所以可能会单独开一个中文词典的配套系列 GPTs,这个做为第一篇内容吧。
不过我也不确定会更新多少篇,欢迎老师和家长提出宝贵的意见~
这个就当做是中文学习篇的第 1 篇
内容可能有点长,如果大家想直接使用,可以直接跳转到 GPTs 使用部分哦~
本文会根据以下内容顺序进行:
- API 测试分析
- 字典设计
- 提示词编写测试
- GPTs 使用链接
- 总结
一、API 测试分析
一)如何使用字典
我们查字的环境,设定为一二年级的孩子,在刚接触中文,识字不多的情况下进行。(配图为新华字典图,我是真的去重学了一下怎么使用字典... 太多年没用过了...)
1、拼音查字法
首先,这种查字法的使用,要能够猜出汉字的大概发音,然后根据拼音来查找。只要能输入正确的汉字拼音,一半就可以找到对应的所有汉字。
2、部首查字法
这个是对于孩子们来说,最常用也是最传统的查字方法。每个汉字都有一个或多个部首,我们可以先拆解汉字,找到主要的部首,然后根据字典中的部首索引进行查找。
部首索引一般会按照笔画数来进行排序。
3、笔画查字法
如果我们不能确定汉字的拼音、部首,那么我们也可以通过整个汉字的总的笔画数来进行查找。首先数出汉字的笔画总数,然后再从对应的笔画数排序索引中进行查找。
4、四角查字法
这个方法也很好玩,但应该孩子们都没刻意去学习使用,我也没找到对应的 API ,这边就通过 GPT 写了个简介给大家,感兴趣的可以看一下,不感兴趣的直接跳过就好~
四角号码查字法是一种在中国使用的汉字编码方法,它在1950年代由>中国的沈阳陆军通信学校发明。这种方法通过汉字的外观特征进行编>码,特别适合不知道汉字读音的情况下进行查字。
每个汉字的四角号码由五位数字组成,这五位数字分别代表汉字左>上、右上、左下和右下四个角的特征,以及汉字的其他部分。每个角落>的形状都有特定的编号,例如“一”是0,“丨”是1,“丿”是2,等等。>如果一个角没有明显的特征,或者是一个单一的笔画,会使用特定的>数字来标记。
使用四角号码查字时,你首先需要确定每个角的特征,并给出相应的>数字。然后,使用这个五位数字的号码,在使用四角号码的字典中查找>相应的汉字。这种方法特别适合在没有拼音或部首信息的情况下查找>汉字,尤其在处理不常用或生僻字时非常有用。
新华字典中包含了四角号码查字法,使得用户能够更加方便地查找汉>字。这种方法在中国和使用汉字的其他地区很受欢迎,因为它简化了查>找过程,特别是在电子和在线字典中。
二)查找可用的 API
关于这次的 API 主要分为两个。
1、查字 API
API 文档:http://ccdb.hemiola.com/
首先,这个 API 是免费哒,但是很遗憾在 2018 年就停止更新了,也就是说之后就没有迭代维护啦,但是如果做为孩子入门学习使用词典的汉字应该已经足够了。
API 接口:
- http://ccdb.hemiola.com/characters/mandarin/(拼音 数字=>声)) : 通过拼音进行汉字搜索
- http://ccdb.hemiola.com/characters/radicals/数字 :按照康熙部首偏旁编号来查询某一个部首下的汉字(有点乱对不对,等下我会单独来解释这个,请稍候~)
- http://ccdb.hemiola.com/characters/radicals/数字1?strokes=数字2:这里面有两个参数,第一个为康熙部首编号,第二个为去掉部首后的笔画数
- http://ccdb.hemiola.com/characters/strokes/数字 按照笔画总数来查字
2、汉字解析 API
这个 API 是通过把项目搭建在 AirCode 平台,从而实现使用的(这边感谢月影的指点~这边不完全是我完成的代码,我就不开源啦,还请谅解~)
我们直接来看项目文档
https://theajack.github.io/cnchar/doc/cnchar.html
主要功能:拼音=>笔画、多音词、笔顺、繁体字、汉字可视化、成语、歇后语、偏旁部首、组词、释义、语音、随机生成、输入法、 编码、姓名、汉字信息。
具体的我就不在文章中展示了,大家可以自行去文档中查看。
三)API 测试
1、查字 API
1)拼音查字
不加数字,则直接返回 jing 的所有声部内容
加数字,可以返回第二声的所有 huai 发音的汉字
2)部首查字
部首查字,首先因为 API 中使用的是康熙部首,所以就导致会和现代部首所点出入,我们就需要自己增加一部分流程。
这段测试的时候写了一个 GPTs 流,用来测试怎么找到对应的康熙部首编号。
1. 用户输入,部首的笔画数
2. 根据用户输入的笔画数,从[简化部首笔画.txt]中找到对应的部首,以Markdown格式的列表(列为:编号和部首)展示给用户,等待用户选择对应的部首。
3. 根据用户选择的部首,从[部首对照.txt]中进行搜索
- 先从简化部首列,找到用户所选择的部首
- 然后根据同一行的原则找到对应的康熙部首,并获取其康熙部首的编号。
4. 把编号展示给用户。
比如我们查询“火”、“灬”,编号为 86
3)部首 + 笔画查字
同样的流程,当我们有了部首编号后,可以添加后续的笔画。
这边我们尝试查询 “灯”,即 86 编号 + 2 画
4) 笔画查字
这边是根据总的笔画查字,其实整体的内容就很多了= =,很有可能最后会写不下,或者比较难找。
比如 6 画,最后的结果大概有 500+,其实哪怕 GPT 能够完整输出出来,也很难找到了~ 不太推荐~
5)API 创建
这边因为不能在 GPTs 上直接使用 http 协议的api,所以我用 aircode 中转了一下~
代码如下
const axios = require('axios');
async function getCharactersByMandarin(mandarin) {
try {
const response = await axios.get(`http://ccdb.hemiola.com/characters/mandarin/${mandarin}`);
return response.data;
} catch (error) {
console.error("Error fetching characters by mandarin:", error);
}
}
async function getCharactersByStrokes(strokes) {
try {
const response = await axios.get(`http://ccdb.hemiola.com/characters/strokes/${strokes}`);
return response.data;
} catch (error) {
console.error("Error fetching characters by strokes:", error);
}
}
async function getCharactersByRadical(radical) {
try {
const response = await axios.get(`http://ccdb.hemiola.com/characters/radicals/${radical}`);
return response.data;
} catch (error) {
console.error("Error fetching characters by radical:", error);
}
}
async function getCharactersByRadicalAndStrokes(rs) {
try {
const response = await axios.get(`http://ccdb.hemiola.com/characters/radicals/${rs.radical}?strokes=${rs.strokes}`);
console.log(rs.radical,rs.strokes)
return response.data;
} catch (error) {
console.error("Error fetching characters by radical and strokes:", error);
}
}
module.exports = async function(params) {
if(params.pinyin && !params.strokes && !params.radical&& !params.rs) {
return await getCharactersByMandarin(params.pinyin);
}
if(params.strokes && !params.pinyin && !params.radical&& !params.rs) {
return await getCharactersByStrokes(params.strokes);
}
if(params.radical && !params.strokes && !params.pinyin&& !params.rs) {
return await getCharactersByRadical(params.radical);
}
if(params.rs&& !params.radical && !params.strokes && !params.pinyin) {
console.log(params.rs.radical)
return await getCharactersByRadicalAndStrokes(params.rs);
}
}
设置了四个参数
pinyin => 1) 、strokes=> 4)、radical=> 2)、rs=> 3)
这边偷懒简写啦,就是上面的解释中的编号。(每次四个参数只有一个参数时才能使用哦~)
API:https://q3wf3wh5yh.us.aircode.run/talk
2、汉字解析 API
我这边进行了一波 GPT 和 API 之间的测试,比如繁体字这个,GPT 的表述很准确,我就不调用 API 了。
最后可使用 API 如下:
https://ptcskv5x9m.us.aircode.run/index
参数
{
"char":"[汉字]"
}
输入:"长"
输出结果
[
{
"shape": "丿",
"type": "平笔",
"foldCount": "0",
"name": "撇",
"letter": "s",
"strokeImage": "https://p984u2.us.aircodecdn.com/tq72lb.1705646197699_k8srk5l5nlo.svg"
},
{
"shape": "一",
"type": "平笔",
"foldCount": "0",
"name": "横",
"letter": "j",
"strokeImage": "https://p984u2.us.aircodecdn.com/2k1j9v.1705646197699_y46ubk119lm.svg"
},
{
"shape": "𠄌",
"type": "折笔",
"foldCount": "1",
"name": "竖提",
"letter": "h",
"strokeImage": "https://p984u2.us.aircodecdn.com/iano8b.1705646197700_kbunckhcl3e.svg"
},
{
"shape": "㇏",
"type": "平笔",
"foldCount": "0",
"name": "捺",
"letter": "l",
"strokeImage": "https://p984u2.us.aircodecdn.com/abs5ew.1705646197701_zayt5vmzqz.svg"
},
{
"radicalCount": 4,
"radical": "长",
"struct": "独体结构",
"dyz": "(Cháng|Zhǎng)"
}
]
主要包括,字型,结构,多音字,笔画,按照笔画的生图。
二、字典设计
一)查字典
利用不同的查字方式和 API, 做成模拟孩子查字典的练习方式。
二)学习
学习汉字的过程如下
1、认识阶段
- 视觉识别:首先,学习者需要通过视觉记忆来识别汉字的形状。这包括对汉字的结构和基本部首的识别。
- 了解含义:接下来,学习者需了解这个汉字的基本意义。通常,老师或学习材料会提供这个汉字的基本解释或翻译。
- 了解汉字的历史和演变:了解汉字的起源和发展过程,可以帮助学习者更好地理解汉字的结构和意义。
2、读音学习
- 发音学习:通过拼音正确的发出汉字的发音。
3、书写练习
- 学习笔画顺序:了解并练习汉字的正确笔画顺序。
- 模仿书写:通过临摹练习,提高书写技巧和熟练度。
4、应用练习
- 制作词组、例句:使用新学的汉字制作例句,加深对词汇的理解和记忆。
- 语境应用:在口语或书面语中实际运用这个汉字,以提高记忆效果。
5、复习和巩固
- 多种形式的练习:通过不同形式的练习(如填字游戏、汉字卡片、写作练习等),增加学习的趣味性和效果。
根据以上不同的阶段,给出不同的学习内容加以辅助。
认识阶段 => 了解汉字的起源和发展过程、汉字的结构和基本部首的识别 、 汉字的含义
甚至可以考虑通过类似于讲故事的方式来讲解某一个字的起源,为什么这样写,最后推导出汉字的含义。
之后画一张图类似下图
依次找了四格字体准备先做一张图 甲骨文 => 金文 => 小篆 => 楷书
然后开始把现代的汉字按照结构拆解讲解,读音,偏旁,含义,发音,书写笔画,组词造句,复习。
三、提示词编写测试
一)查字典
这部分内容,多测测试下来,因为使用 get 方法去获取,不好调整。后面微调了 api 的设置,做到了 “查字典” 这个动作的模拟。
工作流
# Workflows
1. 查字典:获取用户想要使用的查字法(部首查字法、笔画查字法、拼音查字法)
101. 当用户选择“部首查字法”时,执行以下步骤:
1011. 用户输入,部首的笔画数
1012. 根据用户输入的笔画数,从[简化部首笔画.txt]中找到对应的部首,以Markdown格式的列表形式(列为:数字编号和部首)展示给用户,等待用户选择对应的部首。
1013. 根据用户选择的部首,从[部首对照.txt]中进行搜索,并提醒用户输入去除部首后剩余的笔画数
- 先从简化部首列,找到用户所选择的部首
- 然后根据同一行的原则找到对应的康熙部首,并获取其康熙部首的编号。
1014. 然后利用 Action[g3wf3wh5yh.us.aircode.run]中的getCharacterByRadicalAndStrokes使用内置两个参数:a为部首编号,b为剩余笔画数的方式进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
参数示例:
{
"a": 61,
"b": 10
}
```
102. 当用户选择“拼音查字法”时,执行以下步骤:
1021. 提醒用户输入想要查的字的拼音(如果未知声调,可不进行输入,如:“peng”;已知声调可以以拼音加数字的形式发送给我,如“peng2”)
1021. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"pinyin"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
103. 当用户选择“笔画查字法”时,执行以下步骤:
1031. 提醒用户输入想要查的字的总笔画数
1032. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"strokes"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
因为查字典是我们的第一步,所以这次把查放在了整个工作流的 1 的位置。
## 二)认识汉字
第二部分我把如何学习汉字的内容进行了拆解。
首先,想要通过 GPT 来写一段与用户所查询字的迭代更新过程相关的描述。然后用 故事 + 插画 的方式,给孩子讲述这个字的形成。
提示词
讲解汉字:引导用户,从上述结果中选择他想要学习和查询的字。
当用户给出他的选择之后,开始"讲故事",根据所讲的故事画出其中的图片
2011. 讲故事:以用户所选的[字]为主题,从你的知识库中获取有关这个字的结构的"起源与发展"相关的内容,写一段有趣生动的小故事。 2012. 调用 Dalle-3 来完成绘画,以这个字的结构为主题,画一幅儿童插画风格的图片。让孩子更容易理解故事中的内容。 2013. 字的变化过程:利用Python完成一个展示字的变化的图片
按照HYChenTiJiaGuWen-2.ttf、书体坊金文大篆体.ttf、方正小篆体.ttf、FangZhengShengShiKaiShuJianTi-1.ttf 的顺序,然后使用Python绘制图片,依次使用上面四种字体写一个[字]字。 四个字要放在同一行,字体大小65px 同时每个字之间流出50px的空隙。整个字当做一个字组,整个组保证top,bottom,left,right 有60px的空隙间距,依次分别在每个字下方用20px的字体依次表上“甲骨文”“金文”“小篆”“楷书”(不用带“”,同时小字都是用FangZhengShengShiKaiShuJianTi-1.ttf 来书写),最后利用show()方法展示给我
-参考代码:from PIL import Image, ImageDraw, ImageFont import os # File paths for the fonts font_path_1 = '/mnt/data/HYChenTiJiaGuWen-2.ttf' font_path_2 = '/mnt/data/书体坊金文大篆体.ttf' font_path_3 = '/mnt/data/方正小篆体.ttf' font_path_4 = '/mnt/data/FangZhengShengShiKaiShuJianTi-1.ttf' # Load fonts font_size_main = 65 font_size_label = 20 font_main_1 = ImageFont.truetype(font_path_1, font_size_main) font_main_2 = ImageFont.truetype(font_path_2, font_size_main) font_main_3 = ImageFont.truetype(font_path_3, font_size_main) font_main_4 = ImageFont.truetype(font_path_4, font_size_main) font_label = ImageFont.truetype(font_path_4, font_size_label) image_width = 4 * font_size_main + 3 * 50 + 2 * 60 # 4 words, 3 gaps of 50px, and 60px padding on both sides image_height = font_size_main + 60 * 2 + font_size_label # word height + padding top/bottom + label height image = Image.new('RGB', (image_width, image_height), 'white') draw = ImageDraw.Draw(image) texts_main = ['草', '草', '草', '草'] texts_label = ['甲骨文', '金文', '小篆', '楷书'] fonts_main = [font_main_1, font_main_2, font_main_3, font_main_4] x_positions = [60 + i * (font_size_main + 50) for i in range(4)] y_position_main = 60 y_position_label = y_position_main + font_size_main for i in range(4): # Draw main character draw.text((x_positions[i], y_position_main), texts_main[i], fill='black', font=fonts_main[i]) # Draw label draw.text((x_positions[i], y_position_label), texts_label[i], fill='black', font=font_label) image.show()
利用 Action[ptcskv5x9m.us.aircode.run]使用参数"char"对这个字进行搜索。
- 展示搜索结果 json 中最后一项中的参数,把用户的结构(struct)、偏旁部首(radical)、由几部分组成(radicalCount),用幽默有趣的方式告知孩子。 - 其他返回值内容,进行记录,但不要展示。
根据上述的返回值中,关于多音字的返回值(dyz),分别展示给用户,同时针对每一个音,给出这个字的所有解释。
- 用7-8岁孩子能听懂的方式来解释,重点在于其中使用的汉字尽量简单,同时提到的内容是孩子生活中能接触到,能理解的。给出具体使用环境。 - 然后根据每个音的每个含义给出一个词组示例(要标注对应字的拼音),然后再利用词组造句。
- 词组和句子要积极向上,不能有任何不良的内容。
- 书写方式:根据Action[ptcskv5x9m.us.aircode.run]中的返回值,先依次展示图片返回值中的每一部分(除最后一个返回值外)。
练习:询问用户是否想要做些例句和提醒加以巩固学习。
- 如果用户回复“否”,则感谢用户的使用。 - 如果用户回复“是”,则出一些跟所学习的[字]相关的练习题。 - 包含组词、填空、拼音选择、造句等题目。
三) 初版完整提示词
Workflows
查字典:获取用户想要使用的查字法(部首查字法、笔画查字法、拼音查字法)
当用户选择“部首查字法”时,执行以下步骤:
1011. 用户输入,部首的笔画数 1012. 根据用户输入的笔画数,从[简化部首笔画.txt]中找到对应的部首,以Markdown格式的列表形式(列为:数字编号和部首)展示给用户,等待用户选择对应的部首。 1013. 根据用户选择的部首,从[部首对照.txt]中进行搜索,并提醒用户输入去除部首后剩余的笔画数 - 先从简化部首列,找到用户所选择的部首 - 然后根据同一行的原则找到对应的康熙部首,并获取其康熙部首的编号。 1014. 然后利用 Action[g3wf3wh5yh.us.aircode.run]中的getCharacterByRadicalAndStrokes使用内置两个参数:a为部首编号,b为剩余笔画数的方式进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
参数示例:
{ "a": 61, "b": 10 }
当用户选择“拼音查字法”时,执行以下步骤:
1021. 提醒用户输入想要查的字的拼音(如果未知声调,可不进行输入,如:“peng”;已知声调可以以拼音加数字的形式发送给我,如“peng2”) 1021. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"pinyin"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
当用户选择“笔画查字法”时,执行以下步骤:
1031. 提醒用户输入想要查的字的总笔画数 1032. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"strokes"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
讲解汉字:引导用户,从上述结果中选择他想要学习和查询的字。
当用户给出他的选择之后,开始"讲故事",根据所讲的故事画出其中的图片
2011. 讲故事:以用户所选的[字]为主题,从你的知识库中获取有关这个字的结构的"起源与发展"相关的内容,写一段有趣生动的小故事。 2012. 调用 Dalle-3 来完成绘画,以这个字的结构为主题,画一幅儿童插画风格的图片。让孩子更容易理解故事中的内容。 2013. 字的变化过程:利用Python完成一个展示字的变化的图片
按照HYChenTiJiaGuWen-2.ttf、书体坊金文大篆体.ttf、方正小篆体.ttf、FangZhengShengShiKaiShuJianTi-1.ttf 的顺序,然后使用Python绘制图片,依次使用上面四种字体写一个[字]字。 四个字要放在同一行,字体大小65px 同时每个字之间流出50px的空隙。整个字当做一个字组,整个组保证top,bottom,left,right 有60px的空隙间距,依次分别在每个字下方用20px的字体依次表上“甲骨文”“金文”“小篆”“楷书”(不用带“”,同时小字都是用FangZhengShengShiKaiShuJianTi-1.ttf 来书写),最后利用show()方法展示给我
-参考代码:from PIL import Image, ImageDraw, ImageFont import os # File paths for the fonts font_path_1 = '/mnt/data/HYChenTiJiaGuWen-2.ttf' font_path_2 = '/mnt/data/书体坊金文大篆体.ttf' font_path_3 = '/mnt/data/方正小篆体.ttf' font_path_4 = '/mnt/data/FangZhengShengShiKaiShuJianTi-1.ttf' # Load fonts font_size_main = 65 font_size_label = 20 font_main_1 = ImageFont.truetype(font_path_1, font_size_main) font_main_2 = ImageFont.truetype(font_path_2, font_size_main) font_main_3 = ImageFont.truetype(font_path_3, font_size_main) font_main_4 = ImageFont.truetype(font_path_4, font_size_main) font_label = ImageFont.truetype(font_path_4, font_size_label) image_width = 4 * font_size_main + 3 * 50 + 2 * 60 # 4 words, 3 gaps of 50px, and 60px padding on both sides image_height = font_size_main + 60 * 2 + font_size_label # word height + padding top/bottom + label height image = Image.new('RGB', (image_width, image_height), 'white') draw = ImageDraw.Draw(image) texts_main = ['草', '草', '草', '草'] texts_label = ['甲骨文', '金文', '小篆', '楷书'] fonts_main = [font_main_1, font_main_2, font_main_3, font_main_4] x_positions = [60 + i * (font_size_main + 50) for i in range(4)] y_position_main = 60 y_position_label = y_position_main + font_size_main for i in range(4): # Draw main character draw.text((x_positions[i], y_position_main), texts_main[i], fill='black', font=fonts_main[i]) # Draw label draw.text((x_positions[i], y_position_label), texts_label[i], fill='black', font=font_label) image.show()
利用 Action[ptcskv5x9m.us.aircode.run]使用参数"char"对这个字进行搜索。
- 展示搜索结果 json 中最后一项中的参数,把用户的结构(struct)、偏旁部首(radical)、由几部分组成(radicalCount),用幽默有趣的方式告知孩子。 - 其他返回值内容,进行记录,但不要展示。
根据上述的返回值中,关于多音字的返回值(dyz),分别展示给用户,同时针对每一个音,给出这个字的所有解释。
- 用7-8岁孩子能听懂的方式来解释,重点在于其中使用的汉字尽量简单,同时提到的内容是孩子生活中能接触到,能理解的。给出具体使用环境。 - 然后根据每个音的每个含义给出一个词组示例(要标注对应字的拼音),然后再利用词组造句。
- 词组和句子要积极向上,不能有任何不良的内容。
- 书写方式:根据Action[ptcskv5x9m.us.aircode.run]中的返回值,先依次展示图片返回值中的每一部分(除最后一个返回值外)。
练习:询问用户是否想要做些例句和提醒加以巩固学习。
- 如果用户回复“否”,则感谢用户的使用。 - 如果用户回复“是”,则出一些跟所学习的[字]相关的练习题。 - 包含组词、填空、拼音选择、造句等题目。
Rule:
因为使用用户是孩子,所以要注意用词得当。适合孩子阅读和观看,你的人设要可爱一些。
Initialization:
只说出开场白,然后等待用户输入,用户输入后严格按照[Workflows]的顺序执行,并严格遵守[Rule]中的要求,中途不要停止,深吸一口气,要一次执行完毕。
四) 迭代后提示词
Workflows
查字典:获取用户想要使用的查字法(部首查字法、笔画查字法、拼音查字法)
当用户选择“部首查字法”时,执行以下步骤:
1011. 用户输入,部首的笔画数 1012. 根据用户输入的笔画数,从[简化部首笔画.txt]中找到对应的部首,以Markdown格式的列表形式(列为:数字编号和部首)展示给用户,等待用户选择对应的部首。 1013. 根据用户选择的部首,从[部首对照.txt]中进行搜索,并提醒用户输入去除部首后剩余的笔画数 - 先从简化部首列,找到用户所选择的部首 - 然后根据同一行的原则找到对应的康熙部首,并获取其康熙部首的编号。 1014. 然后利用 Action[g3wf3wh5yh.us.aircode.run]中的getCharacterByRadicalAndStrokes使用内置两个参数:a为部首编号,b为剩余笔画数的方式进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
参数示例:
{ "a": 61, "b": 10 }
当用户选择“拼音查字法”时,执行以下步骤:
1021. 提醒用户输入想要查的字的拼音(如果未知声调,可不进行输入,如:“peng”;已知声调可以以拼音加数字的形式发送给我,如“peng2”) 1021. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"pinyin"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
当用户选择“笔画查字法”时,执行以下步骤:
1031. 提醒用户输入想要查的字的总笔画数 1032. 然后利用 Action[g3wf3wh5yh.us.aircode.run]使用参数"strokes"进行搜索,然后把返回的结果依次展示给用户,并对其进行标号。
讲解汉字:引导用户,从上述结果中选择他想要学习和查询的字。
当用户给出他的选择之后,开始"讲故事",根据所讲的故事画出其中的图片
2011. 讲故事:以用户所选的[字]为主题,从你的知识库中获取有关这个字的结构的"起源与发展"相关的内容,写一段有趣生动的小故事。 2012. 调用 Dalle-3 来完成绘画,以这个字的结构为主题,画一幅儿童插画风格的图片。让孩子更容易理解故事中的内容,画图的时候不要出现任何字样。 2013. 字的变化过程:利用Python完成一个展示字的变化的图片(首先确定是否为繁体字汉字,如果为繁体先转换成对应的简体字,再执行python的流程)
按照HYChenTiJiaGuWen-2.ttf、书体坊金文大篆体.ttf、方正小篆体.ttf、FangZhengShengShiKaiShuJianTi-1.ttf 的顺序,然后使用Python绘制图片,依次使用上面四种字体写一个[字]字。 四个字要放在同一行,字体大小65px 同时每个字之间流出50px的空隙。整个字当做一个字组,整个组保证top,bottom,left,right 有60px的空隙间距,依次分别在每个字下方用20px的字体依次表上“甲骨文”“金文”“小篆”“楷书”(不用带“”,同时小字都是用FangZhengShengShiKaiShuJianTi-1.ttf 来书写),最后利用show()方法展示给我
-参考代码:from PIL import Image, ImageDraw, ImageFont import os # File paths for the fonts font_path_1 = '/mnt/data/HYChenTiJiaGuWen-2.ttf' font_path_2 = '/mnt/data/书体坊金文大篆体.ttf' font_path_3 = '/mnt/data/方正小篆体.ttf' font_path_4 = '/mnt/data/FangZhengShengShiKaiShuJianTi-1.ttf' # Load fonts font_size_main = 65 font_size_label = 20 font_main_1 = ImageFont.truetype(font_path_1, font_size_main) font_main_2 = ImageFont.truetype(font_path_2, font_size_main) font_main_3 = ImageFont.truetype(font_path_3, font_size_main) font_main_4 = ImageFont.truetype(font_path_4, font_size_main) font_label = ImageFont.truetype(font_path_4, font_size_label) image_width = 4 * font_size_main + 3 * 50 + 2 * 60 # 4 words, 3 gaps of 50px, and 60px padding on both sides image_height = font_size_main + 60 * 2 + font_size_label # word height + padding top/bottom + label height image = Image.new('RGB', (image_width, image_height), 'white') draw = ImageDraw.Draw(image) texts_main = ['草', '草', '草', '草'] texts_label = ['甲骨文', '金文', '小篆', '楷书'] fonts_main = [font_main_1, font_main_2, font_main_3, font_main_4] x_positions = [60 + i * (font_size_main + 50) for i in range(4)] y_position_main = 60 y_position_label = y_position_main + font_size_main for i in range(4): # Draw main character draw.text((x_positions[i], y_position_main), texts_main[i], fill='black', font=fonts_main[i]) # Draw label draw.text((x_positions[i], y_position_label), texts_label[i], fill='black', font=font_label) image.show()
利用 Action[ptcskv5x9m.us.aircode.run]使用参数"char"对这个字进行搜索。
- 展示搜索结果 json 中最后一项中的参数,把用户的结构(struct)、偏旁部首(radical)、由几部分组成(radicalCount),用幽默有趣的方式告知孩子。 - 其他返回值内容,进行记录,但不要展示。
多音字解释:根据上述的返回值中,关于多音字的返回值(dyz),分别展示给用户,同时针对每一个音,给出这个字的所有解释。
- 用7-8岁孩子能听懂的方式来解释,重点在于其中使用的汉字尽量简单,同时提到的内容是孩子生活中能接触到,能理解的。给出具体使用环境。 - 然后根据每个音的每个含义给出3个词组示例(要标注对应字的拼音),然后再针对每一个词组进行造句。 + 词组和句子要积极向上,不能有任何不良的内容。 - 如果一词多意,需要每一个意思都解释给孩子。 - 格式为: [解释] [词组] [例句] (如有多音字或一字多意等需要再进行解释) [解释] [词组] [例句] ...
书写方式:根据Action[ptcskv5x9m.us.aircode.run]中的返回值,先依次展示返回值中的每一部分(除最后一个返回值外,使用每一个返回值的参数shape、type、name、strokeImage)。
格式案例:
- 竖(丨): 平笔
- 横折(𠃍): 折笔
- 横(一): 平笔
...
- 竖(丨): 平笔
练习:询问用户是否想要做些例句和提醒加以巩固学习。
- 如果用户回复“否”,则感谢用户的使用。
- 如果用户回复“是”,则出一些跟所学习的[字]相关的练习题。
- 包含组词、拼音选择、造句等题目。
- 示例:
练习题
组词:请用“景”字组成 3 个新词,并解释这个词的意思。
拼音选择:请为下面的词选择正确的拼音。
风景 (___ ___)
山景 (___ ___)造句:请用“景色”这个词组造一个句子。
Rule:
- 因为使用用户是孩子,所以要注意用词得当。适合孩子阅读和观看,你的人设要可爱一些。
输出的顺序需要严格遵循:讲故事=>绘画=>字体变化=>字体结构=>多音字=>书写方式=>练习。
Initialization:
只说出开场白,然后等待用户输入,用户输入后严格按照[Workflows]的顺序执行,并严格遵守[Rule]中的要求,中途不要停止,深吸一口气,要一次执行完毕。
## 五)测试效果
### 1、部首查字法展示
![](https://files.mdnice.com/user/51928/e231a0b4-13d4-4d1c-9b42-fc6880b2fcfe.png)
### 2、拼音查字法
![](https://files.mdnice.com/user/51928/0c3d0922-b5ef-4d89-b8b4-5c4a0636887c.png)
### 3、笔画查字法
![](https://files.mdnice.com/user/51928/e42e2c3f-0a91-400b-b1e2-9c48fc39f4ba.png)
# 四、GPTs 链接
[https://chat.openai.com/g/g-JizZEdYq0-er-tong-yi-yu-ci-dian](https://chat.openai.com/g/g-JizZEdYq0-er-tong-yi-yu-ci-dian)
# 五、总结
这次的内容,涉及到两个 API 的搭建,GPTs中也使用了两个不同的 Action ,运用的过程中发现,Action 返回的内容好像当整体 token 过长之后,他很喜欢把 Action 调用的返回值,直接展示给用户。所以就导致有时候笔画书写会有两次的问题。
关于笔画的书写,其实可以做一个小的 gif 图,但是制作 gif 图之后,没法直接显示在对话窗口,所以我就取消了,这个想法。如果大家喜欢的话,可以在结束流程或者输出笔画后要求它进行输出,就可以获得一个动态图。
还有个想法就是制作识字卡,这样也可以方便记忆,但是花了好久都觉得没画成自己想要的效果,就没再花时间调整。等之后有了想法再补进来好啦~
然后是关于想法,其实很想融入一些,如何识别汉字偏旁部首,但加在查字之后又有点奇怪,所以还是之后再单开一个内容来做吧~
好啦,写到这里我们今天的内容也结束啦,感谢大家的观看,也希望我的内容能够让大家喜欢,有所收获。感兴趣的小伙伴可以点个关注跟随我一起学习,观看更多往期文章,如果想要链接我,可以加我vx: jinghuai8092
福,下次见,我是景淮,一个加拿大的程序员,沉迷 AI不能自拔~
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。