一分钟图表:简易统计图表模型设计与实现

2024-04-22 06:32

本文主要是介绍一分钟图表:简易统计图表模型设计与实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 目的

在系统后台,很多地方都需要以直观的方式呈现相关统计数据,然而总是从查询语句、接口、页面到图表的过程,繁琐费时。对于简单的统计需求,期望建立合适的模型,简化这个过程,并使得整个过程聚焦数据本身,快捷而简单,并为整个过程的配置化提供可能。

2. 图表要素

这里只讨论简单的统计需求。
要素一:标题 和 统计数据
要素二:图表类型(饼图、柱状图、线图)

3. 约定

统计数据的标签与值属性名总是使用 name、value,更多维度时也总是先进行约定后再使用。

4. 期待效果

给定一个名字或是编号,得到相关数据,指定图表类型呈现。
具体描述:
(1)可配置数据语句、图表标题及指定一个编号
(2)提供一个接口通过指定编号可取得数据
(3)指定图表类型,将数据应用到该图表(进一步完善可直接配置生成图表页)

5. 数据的模型设计

create table t_chart_data(id int primary key,code varchar(40) not null,        -- 编号chart_title varchar(80) not null, -- 图表标题query varchar(2000),              -- 数据查询语句note varchar(200),                -- 备注status bool                       -- 状态
);
-- code 设置唯一索引
create unique index uidx_chart_data_code on t_chart_data(code);
create sequence seq_chart_data_id;

6. 数据接口

提供通过编号取得数据的接口方法。这里插入一条数据用于测试。

INSERT INTO t_chart_data(id, code, chart_title, query, note, status)VALUES (1, 'test', '测试图表', 'select ''name'' as name, 1 as value', null, true);

以下为 c# 实现的一个根据 code 读取并形成接口数据的简单实现。

public static JObject GetChartData(string code)
{JObject result = new JObject();string sql = "select chart_title, query from t_chart_data where code=@code";var dt = PostgreSQLHelper.ExecuteQuery(ServiceTableHelper.QryHelper.ConnectString, CommandType.Text, sql, new NpgsqlParameter("code", code)).Tables[0];if (dt.Rows.Count == 0){result["err_code"] = 101;result["err_msg"] = "未找到相关配置!";return result;}string chartTitle = dt.Rows[0]["chart_title"] as string;string query = dt.Rows[0]["query"] as string;// 以下数据查询可以带上环境参数实现不同上下文不同查询结果try{var data = PostgreSQLHelper.ExecuteQuery(ServiceTableHelper.QryHelper.ConnectString, CommandType.Text, query).Tables[0];result["err_code"] = 200;result["err_msg"] = "success";result["chart_title"] = chartTitle;result["data"] = JArray.Parse(JsonConvert.SerializeObject(data));return result;}catch(Exception e){result["err_code"] = 101;result["err_msg"] = e.Message;return result;}
}

如,传参 code=test,将得到以下结果:

{"err_code": 200,"err_msg": "success","chart_title": "测试图表","data": [{"name": "name","value": 1}]
}

7. 简易图表接口

期待效果:在指定位置,以指定图表呈现数据。通过封装 echarts 形成工具接口类。
如 EchartsTool.bar("elementId", data); 形式,封装中会默认一种样式。
一个简单的封装版本可在这里找到:
https://github.com/triplestudio/helloworld/blob/master/echarts-tool.js

8. 实际应用

引入相关 js

<script src="jquery-1.10.2.min.js" type="text/javascript"></script>
<script src="https://cdn.bootcss.com/echarts/4.6.0/echarts.min.js"></script>
<script src="echarts-tool.js"></script>

可以使用以下方式加载数据,并呈现,如下为柱状与饼图示例。

$(function(){$.post("api/chartdata.aspx", { code: "test" }, function (resp) {$("#userStatTitle").text(resp.chart_title);EchartsTool.bar("userStat", resp.data);});$.post("api/chartdata.aspx", { code: "test" }, function (resp) {$("#demo2Title").text(resp.chart_title);EchartsTool.pie("demo2", resp.data);});
});

执行效果如下图:

这篇关于一分钟图表:简易统计图表模型设计与实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/925028

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了