与copilot 结对编程系列 - log日志重复性检测 - 第4篇 - 网页UI界面

news2024/11/15 8:03:37

背景

细节可以参考这篇文章: 与copilot 结对编程系列 - log日志重复性检测 - 第1篇 - 总体介绍及效果展示

本文主要将数据库中存储的数据通过网页调用并展示出来, 以下是对详细解释。

web框架选择

当前场景使用 Flask 来展示网页信息.
主要原因如下:

  1. 轻量级和易于使用:Flask 是一个轻量级的 Web 框架,易于设置和使用。它允许开发者快速构建和部署 Web 应用程序,而不需要复杂的配置。
  2. 模板渲染:Flask 提供了强大的模板引擎 Jinja2,可以方便地将 Python 数据传递到 HTML 模板中进行渲染。在 result.html文件中,使用了 Jinja2 模板语法(如 {{ log_results | tojson | safe }})来将后端数据传递到前端。
  3. 路由管理:Flask 提供了简单的路由机制,可以轻松地将 URL 映射到特定的函数。在 app.py文件中,可以定义不同的路由来处理不同的请求,并返回相应的 HTML 页面或数据。
  4. 数据处理:在 database_query.py等脚本中,可以使用 Flask 处理从数据库中查询的数据,并将其传递到前端进行展示。Flask 可以与各种数据库(如 SQLite、MySQL、PostgreSQL)无缝集成。
  5. 扩展性:Flask 拥有丰富的扩展库,可以轻松地添加各种功能,如表单处理、用户认证、文件上传等。开发者可以根据需要选择合适的扩展来增强应用的功能。
  6. 开发和调试:Flask 提供了内置的开发服务器和调试工具,可以方便地进行本地开发和调试。开发者可以快速迭代和测试代码,提升开发效率。

综上所述,Flask 作为一个轻量级且功能强大的 Web 框架,非常适合用于当前场景中展示网页信息的需求。

具体实现

ui_interface.py 这是一个 Flask 应用程序

它通过前端表单接收用户输入的数据,调用数据库接口进行查询,然后将处理后的结果展示在页面上。以下是详细的步骤:

  1. 接收前端数据

    • 用户在前端表单中输入数据并提交表单。
    • 表单数据通过 POST 请求发送到服务器端的 /query 路由。
  2. 处理请求

    • /query 路由中,使用 request.form 获取表单数据。
    • 根据表单数据中的query_type 字段,选择相应的数据库查询函数。
  3. 调用数据库接口

    • 根据query_type,调用 database_query 模块中的相应函数进行数据库查询。
    • 查询函数返回查询结果 log_results 和摘要结果summary_result
  4. 处理查询结果

    • 使用 process_json 函数对查询结果进行处理,添加前缀到键名。
    • 将处理后的结果存储在 Flask 的 session 中,以便后续使用。
  5. 展示结果

    • 将处理后的查询结果传递给模板引擎 render_template,渲染 result.html 页面。
    • result.html 页面中展示查询结果。

以下是代码中的关键部分:

@app.route('/query', methods=['POST'])
def query_result():
    # 获取表单数据
    query_type = request.form['query_type']
    log_level = request.form.get('log_level')
    log_type = request.form.get('log_type')
    limit = request.form.get('limit')
    log_procedure = request.form.get('log_procedure')
    file_line = request.form.get('file_line')
    order_by_field = request.form.get('order')
    sct_case_name = request.form.get('sct_case_name')

    # 根据 query_type 调用相应的数据库查询函数
    query_functions = {
        'query_single_sct_case': lambda: ds.query_single_sct_case(sct_case_name),
        'query_top_sct_cases': lambda: (ds.query_top_sct_cases(log_level, log_type, limit), {}),
        'query_log_types_ranking': lambda: (ds.query_log_types_ranking(log_level), {}),
        'query_top_log': lambda: (ds.query_top_log(log_procedure, log_level, log_type, limit, order_by_field), {}),
        'query_specific_log': lambda: (ds.query_specific_log(file_line, limit), {}),
        'query_logs_by_type': lambda: (ds.query_logs_by_type(log_type, limit), {}),
        'query_pet_log_type': lambda: (ds.query_pet_log_type(), {}),
        'query_pet_top_log_ranking': lambda: (ds.query_pet_top_log_ranking(log_procedure, log_level, log_type, limit), {})
    }
    # 执行查询函数
    log_results, summary_result = query_functions.get(query_type, lambda: ({}, {}))()
    # 处理查询结果
    log_results = process_json(log_results)
    summary_result = process_json(summary_result) if summary_result else {}
    # 将结果存储在 session 中
    session['log_results'] = log_results
    session['summary_result'] = summary_result
    # 渲染结果页面
    return render_template('result.html', query_type=query_type, log_results=log_results, summary_result=summary_result)

通过上述步骤,脚本实现了从前端接收数据、调用数据库接口、处理查询结果并展示在页面上的完整流程。

index.html

这个 index.html 文件是一个前端页面,主要用于提供一个查询接口。它的主要功能和作用如下:

  1. 页面结构和样式

    • 使用 HTML 和 CSS 定义了页面的基本结构和样式。
    • 页面包含一个标题、一个表单和一个计时器显示区域。
    • 表单包含两个下拉菜单(查询类别和查询类型)和一个动态参数容器。
  2. 动态表单生成

    • 根据用户选择的查询类别和查询类型,动态生成表单参数。
    • 使用 JavaScript 脚本,根据预定义的 queryOptionsqueryParams 对象,动态更新查询类型选项和参数输入字段。
  3. JavaScript 脚本

    • updateQueryTypeOptions():根据选择的查询类别,更新查询类型的下拉菜单选项。
function updateQueryTypeOptions() {
    const queryCategory = document.getElementById('query_category').value;
    const queryTypeSelect = document.getElementById('query_type');
    queryTypeSelect.innerHTML = '';
    queryOptions[queryCategory].forEach(option => {
        const opt = document.createElement('option');
        opt.value = option.value;
        opt.textContent = option.text;
        queryTypeSelect.appendChild(opt);
    });
    showParams();
}
  • showParams():根据选择的查询类别和查询类型,动态生成相应的参数输入字段。
function showParams() {
    const queryCategory = document.getElementById('query_category').value;
    const queryType = document.getElementById('query_type').value;
    const paramsContainer = document.getElementById('params_container');
    paramsContainer.innerHTML = '';
    const params = queryParams[`${queryCategory}_${queryType}`];
    if (params) {
        params.forEach(param => {
            const label = document.createElement('label');
            label.setAttribute('for', param.id);
            label.textContent = param.label;
            paramsContainer.appendChild(label);

            if (param.type === 'select') {
                const select = document.createElement('select');
                select.id = param.id;
                select.name = param.name;
                param.options.forEach(option => {
                    const opt = document.createElement('option');
                    opt.value = option;
                    opt.textContent = option;
                    select.appendChild(opt);
                });
                paramsContainer.appendChild(select);
            } else {
                const input = document.createElement('input');
                input.type = param.type;
                input.id = param.id;
                input.name = param.name;
                if (param.value) {
                    input.value = param.value;
                }
                paramsContainer.appendChild(input);
            }
        });
    }
}
  • startTimer():在表单提交时启动一个计时器,显示查询时间,并禁用提交按钮以防止重复提交。
function startTimer() {
    const submitButton = document.querySelector('input[type="submit"]');
    submitButton.disabled = true;
    const timerElement = document.getElementById('timer');
    const startTime = Date.now();
    setInterval(() => {
        const elapsedTime = ((Date.now() - startTime) / 1000).toFixed(1);
        timerElement.textContent = 'Query time: ' + elapsedTime + ' seconds';
    }, 100);
    return true; // Allow form submission
}
  • window.onload:页面加载时,默认选择 SCT 查询类别并更新查询类型选项。
window.onload = function() {
    document.getElementById('query_category').value = 'SCT';
    updateQueryTypeOptions();
};
  1. 与 Flask 的集成
    • 表单的 action 属性指向 /query,使用 POST 方法提交数据,这是一个 Flask 路由,用于处理查询请求。
    • Flask 后端会接收表单提交的数据,处理查询逻辑,并返回结果。

总结来说,这个文件主要用于提供一个用户界面,让用户选择查询类别和类型,并输入相应的参数,然后提交查询请求到 Flask 后端进行处理。

results.html

这个 result.html 文件是一个 HTML 模板文件,通常用于 Flask 应用中,用来展示查询结果。以下是这个文件的主要作用和功能:

  1. 页面结构和样式

    • 使用 HTML 和 CSS 定义了页面的结构和样式。
    • 包含一个标题 “Query Result”。
    • 定义了一些样式规则,使页面看起来更美观,例如背景颜色、字体、表格样式等。
  2. 数据处理和展示

    • 使用 JavaScript 函数 removePrefixFromKeys 去除数据键中的前缀。
    • 使用 generateTablegenerateSingleRowTable 函数生成 HTML 表格,用于展示查询结果。
    • 将处理后的数据插入到页面的特定容器中 (log-results-containersummary-results-container)。
  3. 导出功能

    • 提供了一个链接,允许用户将查询结果导出为 Excel 文件。
  4. 图表展示

    • 如果查询类型是 query_log_types_rankingquery_pet_log_type,则会生成一个饼图来展示日志类型的排名。
    • 使用 Chart.js 库生成图表,并对图表进行了一些自定义设置,例如颜色、图例等。
  5. 模板引擎

    • 使用了 Jinja2 模板引擎的语法(例如 {{ log_results | tojson | safe }}{% if query_type == 'query_log_types_ranking' or query_type == 'query_pet_log_type' %})来动态渲染数据和条件内容。

这个文件的主要作用是展示查询结果,包括表格和图表,并提供导出功能。它是 Flask 应用的一部分,通过 Flask 渲染并返回给客户端。

最终效果演示

界面查询

提供多个categories, 用于后期扩展
在这里插入图片描述
对于特地category, 当前提供了6个查询接口
在这里插入图片描述

数据展示

表格数据展示, 提供了占比, 总数, 排名等等信息
在这里插入图片描述
提供了可视化图表, 更加直观体现
在这里插入图片描述
提供excel一键导出, 便于离线数据分析
在这里插入图片描述

最后

后续展望, 当前的脚本还存在诸多问题,后期准备增加功能:

  • 周期性运行部署, 监控log日志的趋势
  • 历史版本比较, 往不好方向发展, 可以及时知晓
  • 更多log日志格式支持
  • 邮件通知
    等等
    有兴趣, 需要源码可以关注我的公众号, 代码的更多细节, 一起交流~~~
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2071474.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何使用JavaScript获取HTML表单中的值?

在开发中,我们经常需要获取用户在表单中输入的数据,然后进行处理或提交到服务器。今天我们就来聊一聊,如何用JavaScript获取HTML表单中的值。 使用 FormData 构造函数 FormData 是一个非常方便的工具,它可以把表单中的所有数据打包…

C++,std::chrono 详解

文章目录 1. 概述2. 时间点(Time Points)3. 时间间隔(Durations)4. 时钟(Clocks)5. 时间算术6. 时间转换7. 延时参考 1. 概述 std::chrono 是 C11 引入的一个库,用于处理日期和时间。它提供了一…

Unsloth 教程 - 如何微调 Llama-3并导出到 Ollama

本文翻译整理自:🦙 How to Finetune Llama-3 and Export to Ollama https://docs.unsloth.ai/tutorials/how-to-finetune-llama-3-and-export-to-ollama 文章目录 1、什么是Unsloth?2、什么是Ollama?3、安装Unsloth4、选择要微调的…

博弈论总结

公平组合游戏(Impartial Game)的定义如下: 游戏有两个人参与,二者轮流做出决策,双方均知道游戏的完整信息; 任意一个游戏者在某一确定状态可以作出的决策集合只与当前的状态有关,而与游戏者无关…

pytorch深度学习基础 6(简单的参数估计学习3)

上一篇博客说了如何拟合一条直线ywxb,今天我们现在使用PyTorch进行相同的曲线拟合 拟合y x*x -2x 3 0.1(-1到1的随机值) 曲线 给定x范围(0,3) 生成数据 import numpy as np import matplotlib.pyplot as plt import torch as t…

小程序学习day13-API Promise化、全局数据共享(状态管理)、分包

44、API Promise化 (1)基于回调函数的一部API的缺点:小程序官方提供的异步API都是基于回调函数实现的,容易造成回调地狱的问题,代码可读性、可维护性差 (2)API Promise化概念: 指…

Qt 环境搭建

sudo apt-get upadte sudo apt-get install qt4-dev-tools sudo apt-get install qtcreator sudo apt-get install qt4-doc sudo apt-get install qt4-qtconfig sudo apt-get install qt-demos编译指令 qmake -projectqmakemake实现Ubuntu20,04 与Windows之间的复制粘贴 安装o…

在C#中如何监控其它应用全屏

原文链接:https://www.cnblogs.com/zhaotianff/p/18338275 在C#中判断其它应用全屏可以有多种方案。我这里提供两种思路 使用定时器 在定时器中定时判断当前窗口的状态是否是最大化或者宽高是否等于桌面窗口的宽高。 这种方法我没有去尝试,凭个人经验…

复杂的编辑表格

需求描述 表格可以整体编辑;也可以单行弹框编辑;且整体编辑的时候,依然可以单行编辑 编辑只能给某一列(这里是参数运行值)修改,且根据数据内容的参数范围来判断展示不同的形式:input/数字输入/单…

小波卷积:为计算机视觉任务开辟新的参数效率之路

论文复述 这篇论文介绍了一种创新的卷积神经网络层——WTConv,它通过小波变换技术显著扩展了CNN的感受野,同时保持了参数效率。WTConv层能够实现对输入数据的多频率响应,增强了模型对形状而非纹理的特征识别能力,提高了在图像分类…

黑神话悟空不只是玩游戏 有人用它3天赚了85W

这几天你是不是在想办法升级电脑配置,买PS5玩黑神话悟空游戏,每一个男人看到那么好的游戏画面,都控制不住想玩,今天分享给大家一些资料,让你快速玩游戏的同时,还能挣点外快,黑神话悟空不只是玩游…

MATLAB 计算两点沿某个方向的间距(81)

MATLAB 计算两点沿某个方向的间距(81) 一、算法介绍二、算法实现1.代码2.效果一、算法介绍 上一章介绍了如何计算点到空间直线的距离,这里进一步的,我们也可以计算两个点,沿着某个方向的距离,这在很多处理中都会使用到,实际上就是将两点投影到该方向的直线,再计算间距…

线性表复习之初始化顺序表操作

线性表的顺序表示-初始化顺序表 代码 #include <stdio.h> #define MaxSize 10 // 定义最大长度typedef struct{int data[MaxSize]; // 申请空间&#xff08;静态&#xff09;int length; // 当前长度 }SqList;void InitList(SqList &L){for (int i 0; i < MaxS…

java-队列--黑马

队列 别看这个&#xff0c;没用&#xff0c;还是多刷力扣队列题 定义 队列是以顺序的方式维护一组数据的集合&#xff0c;在一端添加数据&#xff0c;从另一端移除数据。一般来讲&#xff0c;添加的一端称之尾&#xff0c;而移除一端称为头 。 队列接口定义 // 队列的接口定…

河南萌新联赛2024第(六)场:郑州大学

目录 A-装备二选一&#xff08;一&#xff09;_河南萌新联赛2024第&#xff08;六&#xff09;场&#xff1a;郑州大学 (nowcoder.com) 思路&#xff1a; 代码&#xff1a; B-百变吗喽_河南萌新联赛2024第&#xff08;六&#xff09;场&#xff1a;郑州大学 (nowcoder.com) …

3DsMax将两个模型的UV展到一个UV上面

3DsMax将两个模型的UV展到一个UV上面 3Dmax中的准备工作 创建一个方块&#xff0c;一个球体&#xff0c;模拟两个模型 添加修改器 打开UV编辑器&#xff0c;快速剥 使用缩放工具&#xff0c;缩放UV&#xff0c;放到一个位置 选择正方形&#xff1a;添加修改器&#xff0…

8.3 数据库基础技术-关系代数

并、交、差 笛卡尔积、投影、选择 自然连接 真题

宝塔面板配置node/npm/yarn/pm2....相关全局变量 npm/node/XXX: command not found

1.打开终端 , cd 到根目录 cd / 2.跳转至node目录下,我的node版本是v16.14.2 cd /www/server/nodejs/v16.14.2/bin 2.1 如果不知道自己node版本多少就跳转到 cd /www/server/nodejs 然后查找当前目录下的文件 ls 确定自己的node版本 cd /node版本/bin 3.继续查看bin…

天润融通助力呷哺呷哺:AI技术赋能3000万会员精细化运营

呷哺集团于1998年11月在北京成立&#xff0c;以“一人一锅”台式小火锅的用餐模式&#xff0c;以及其推出的多样化套餐与良好的用餐服务赢得了众多消费者的青睐&#xff0c;并迅速在市场上占据了一席之地。经过20多年的发展&#xff0c;呷哺呷哺已成为一个多品牌经营、全产业链…

基于Android的安全知识学习APP的设计与实现(论文+源码)_kaic

基于Android的安全知识学习APP的设计与实现 摘 要 随着科技的进步&#xff0c;智能手机已经成为人们工作、学习和生活的必需品。基于Android系统的强大功能&#xff0c;使用Java语言、Linux操作系统&#xff0c;搭配Android Studio&#xff0c;并配备Android开发插件&#…