项目训练营-智能Bi项目详细模块编写
库表设计
-- 用户表
create table if not exists user
(
id bigint auto_increment comment ‘id’ primary key,
userAccount varchar(256) not null comment ‘账号’,
userPassword varchar(512) not null comment ‘密码’,
userName varchar(256) null comment ‘用户昵称’,
userAvatar varchar(1024) null comment ‘用户头像’,
userRole varchar(256) default ‘user’ not null comment ‘用户角色:user/admin’,
createTime datetime default CURRENT_TIMESTAMP not null comment ‘创建时间’,
updateTime datetime default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment ‘更新时间’,
isDelete tinyint default 0 not null comment ‘是否删除’,
index idx_userAccount (userAccount)
) comment ‘用户’ collate = utf8mb4_unicode_ci;
-- 图表信息表
create table if not exists user
(
id bigint auto_increment comment ‘id’ primary key,
goal text null comment ‘分析目标’,
chartData text null comment ‘图表数据’,
chartType varchar(128) null comment ‘图表类型’,
genChart text null comment ‘生成的图表’,
genResult text null comment ‘生成的结论’,
userRole varchar(256) default ‘user’ not null comment ‘用户角色:user/admin’,
createTime datetime default CURRENT_TIMESTAMP not null comment ‘创建时间’,
updateTime datetime default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP comment ‘更新时间’,
isDelete tinyint default 0 not null comment ‘是否删除’,
) comment ‘图表信息表’ collate = utf8mb4_unicode_ci;
功能模块
- Excel 转csv
加上报错后如下:
将报错换成try catch后如下:
末尾加上如下逻辑,用于将Excel格式转换为csv格式
->
->
2. AI模型调用
在manager文件夹中新建AiManager文件,在其中编写代码如下:
Ai题词技巧:
-
- 规定输入、输出格式
-
- 设定身份
-
- 回答中用不会被MarkDown侵吞的字符格式作为分隔符
图像处理:
-
- 采用Echarts前端组件库
-
- 要求输出Echarts option v5格式的前端js格式对象
例如:(此处使用鱼聪明AI系统的新建助手功能,以及对系统进行身份设定的功能进行,鱼聪明AI是鱼鸢网络里的一款产品,微信登陆后每天可免费领五次提问机会)
AI提问代码如下,可参考github上的鱼聪明SDK的相关内容来编写:
- 输入输出,取回数据后拆分
- 测试
- 测试结果图(swagger自带接口文档进行测试)
- 使用方法,配置好环境后,将如下地址修改为对应端口即可直接使用http://localhost:8100/api/doc.html
删除换行和转义字符表示的\后结果如图
修改后不用删除,也能正常运行
数据库数据
- Excel转csv格式数据过滤
Excel表格读取测试情况
过滤代码如下:
用LinkedMap是为了让数据按照键值上的顺序读取出来,过滤原理是filter函数过滤后数据如下:
用户列表查询功能
-
- 根据后端万用模板(编程导航网站获取)中用户列表管理功能简单修改进行测试即可。
-
- 这里也给出网盘链接:
-
- https://pan.baidu.com/s/12pNMmhh48-ACJAwpBMm9oQ?pwd=0o2t
-
- 提取码Oo2t
-
- 效果如下:
- 效果如下: