html做一个分组散点图图的软件

在HTML中创建一个分组散点图,可以结合JavaScript库如D3.js或Plotly.js来实现。这些库提供了强大的数据可视化功能,易于集成和使用。下面是一个使用Plotly.js创建分组散点图的示例:
要添加文件上传功能,可以让用户上传包含数据的文件(例如CSV文件),然后使用JavaScript读取文件并生成散点图。下面是一个示例,展示了如何结合文件上传和用户输入生成分组散点图:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Grouped Scatter Plot with User Input and File Upload</title>
    <script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
</head>
<body>
    <h1>Grouped Scatter Plot</h1>
    <form id="dataForm">
        <h3>Group 1</h3>
        <label for="group1x">X values (comma separated):</label>
        <input type="text" id="group1x" name="group1x" value="1,2,3,4,5"><br>
        <label for="group1y">Y values (comma separated):</label>
        <input type="text" id="group1y" name="group1y" value="10,15,13,17,10"><br>

        <h3>Group 2</h3>
        <label for="group2x">X values (comma separated):</label>
        <input type="text" id="group2x" name="group2x" value="1.5,2.5,3.5,4.5,5.5"><br>
        <label for="group2y">Y values (comma separated):</label>
        <input type="text" id="group2y" name="group2y" value="16,5,11,9,15"><br>

        <h3>Group 3</h3>
        <label for="group3x">X values (comma separated):</label>
        <input type="text" id="group3x" name="group3x" value="2,3,4,5,6"><br>
        <label for="group3y">Y values (comma separated):</label>
        <input type="text" id="group3y" name="group3y" value="6,8,10,14,13"><br>

        <button type="button" onclick="plotData()">Plot Data</button>
    </form>
    
    <h2>Or Upload CSV File</h2>
    <input type="file" id="fileInput" accept=".csv">
    <button type="button" onclick="uploadFile()">Upload and Plot</button>

    <div id="scatter-plot" style="width:100%;height:600px;"></div>

    <script>
        function plotData() {
            var group1x = document.getElementById('group1x').value.split(',').map(Number);
            var group1y = document.getElementById('group1y').value.split(',').map(Number);
            var group2x = document.getElementById('group2x').value.split(',').map(Number);
            var group2y = document.getElementById('group2y').value.split(',').map(Number);
            var group3x = document.getElementById('group3x').value.split(',').map(Number);
            var group3y = document.getElementById('group3y').value.split(',').map(Number);

            var trace1 = {
                x: group1x,
                y: group1y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 1',
                marker: { size: 12 }
            };

            var trace2 = {
                x: group2x,
                y: group2y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 2',
                marker: { size: 12 }
            };

            var trace3 = {
                x: group3x,
                y: group3y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 3',
                marker: { size: 12 }
            };

            var data = [trace1, trace2, trace3];

            var layout = {
                title: 'Grouped Scatter Plot',
                xaxis: {
                    title: 'X Axis'
                },
                yaxis: {
                    title: 'Y Axis'
                }
            };

            Plotly.newPlot('scatter-plot', data, layout);
        }

        function uploadFile() {
            var fileInput = document.getElementById('fileInput');
            var file = fileInput.files[0];
            var reader = new FileReader();

            reader.onload = function(event) {
                var csvData = event.target.result;
                processCSVData(csvData);
            };

            reader.readAsText(file);
        }

        function processCSVData(csvData) {
            var lines = csvData.split('\n');
            var group1x = [], group1y = [], group2x = [], group2y = [], group3x = [], group3y = [];

            for (var i = 1; i < lines.length; i++) {
                var cols = lines[i].split(',');
                if (cols.length === 6) {
                    group1x.push(parseFloat(cols[0]));
                    group1y.push(parseFloat(cols[1]));
                    group2x.push(parseFloat(cols[2]));
                    group2y.push(parseFloat(cols[3]));
                    group3x.push(parseFloat(cols[4]));
                    group3y.push(parseFloat(cols[5]));
                }
            }

            var trace1 = {
                x: group1x,
                y: group1y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 1',
                marker: { size: 12 }
            };

            var trace2 = {
                x: group2x,
                y: group2y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 2',
                marker: { size: 12 }
            };

            var trace3 = {
                x: group3x,
                y: group3y,
                mode: 'markers',
                type: 'scatter',
                name: 'Group 3',
                marker: { size: 12 }
            };

            var data = [trace1, trace2, trace3];

            var layout = {
                title: 'Grouped Scatter Plot',
                xaxis: {
                    title: 'X Axis'
                },
                yaxis: {
                    title: 'Y Axis'
                }
            };

            Plotly.newPlot('scatter-plot', data, layout);
        }
    </script>
</body>
</html>

说明:

  1. HTML表单:用于用户手动输入每个组的X和Y值。
  2. 文件上传:提供了一个文件输入框和按钮,用于上传CSV文件。
  3. JavaScript函数
    • plotData:处理用户输入的数据并生成散点图。
    • uploadFile:读取用户上传的CSV文件,并调用processCSVData函数处理CSV数据。
    • processCSVData:解析CSV数据并生成散点图。

CSV文件格式:

CSV文件应该包含每组的X和Y值,按列排列,例如:

group1x,group1y,group2x,group2y,group3x,group3y
1,10,1.5,16,2,6
2,15,2.5,5,3,8
3,13,3.5,11,4,10
4,17,4.5,9,5,14
5,10,5.5,15,6,13

通过这种方式,用户既可以手动输入数据,也可以通过上传文件来生成分组散点图。你可以根据需要进一步调整和扩展代码。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

使用 Python 进行测试(6)Fake it...

总结 如果我有: # my_life_work.py def transform(param):return param * 2def check(param):return "bad" not in paramdef calculate(param):return len(param)def main(param, option):if option:param transform(param)if not check(param):raise ValueError(…

matlab入门基础笔记

1、绘制简单三角函数&#xff1a; 绘制正弦曲线和余弦曲线。x[0:0.5:360]*pi/180; plot(x,sin(x),x,cos(x)); &#xff08;1&#xff09;明确x轴与y轴变量&#xff1a; 要求为绘制三角函数&#xff1a; X轴&#xff1a;角度对应的弧度数组 Y轴&#xff1a;对应sin(x)的值 求…

python pynput实现鼠标点击两坐标生成截图

脚本主要实现以下功能&#xff1a; 按ctrl开始截图&#xff0c;点击两个坐标&#xff0c;保存截图tk输出截图文本信息&#xff0c;文本输出内容倒序处理默认命名为A0自增。支持自定义名称&#xff0c;自增编号&#xff0c;修改自定义名称自增重新计算清空文本框内容 from pyn…

C++ (week8):数据库

文章目录 一、数据库简介1.数据库2.MySQL(1)数据库的结构(2)MySQL的三种使用方式(3)命令行(4)Navicat Premium 二、SQL1.SQL (Structured Query Language)&#xff0c;即结构化查询语言2.数据定义语言 DDL (Data Definition Language) &#xff0c;创建、修改、删除数据库、表结…

Leetcode3184. 构成整天的下标对数目 I

Every day a Leetcode 题目来源&#xff1a;3184. 构成整天的下标对数目 I 解法1&#xff1a;遍历 统计满足 i < j 且 hours[i] hours[j] 构成整天的下标对 i, j 的数目。 构成整天的条件&#xff1a;(hours[i] hours[j]) % 24 0。 代码&#xff1a; /** lc applee…

20分钟攻破DISCUZ论坛并盗取数据库(web安全白帽子)

20分钟攻破DISCUZ论坛并盗取数据库&#xff08;web安全白帽子&#xff09; 1 快速搭建discuz论坛1.1 攻击思路1.2 快速搭建实验环境1.2.1&#xff0c;漏洞概述1.2.2&#xff0c;在centos7虚拟机上搭建LAMP环境1.2.3&#xff0c;上传到discuz_X2_SC_UTF8.zip 到Linux系统/root下…

JAVA大型医院绩效考核系统源码:​医院绩效考核实施的难点痛点

JAVA大型医院绩效考核系统源码&#xff1a;​医院绩效考核实施的难点痛点 绩效考核数字化综合管理系统是一个基于数字化技术的管理平台&#xff0c;用于帮助企业、机构等组织进行绩效考评的各个环节的管理和处理。它将绩效考评的各个环节集成到一个系统中&#xff0c;包括目标…

RTA_OS基础功能讲解 2.10-调度表

RTA_OS基础功能讲解 2.10-调度表 文章目录 RTA_OS基础功能讲解 2.10-调度表一、调度表简介二、调度表配置2.1 同步三、到期点配置四、启动调度表4.1 绝对启动4.2 相对启动4.3 同步启动五、到期点处理六、停止调度表6.1 重新启动被停止的调度表七、切换调度表八、选择同步策略8.…

【C语言】解决C语言报错:Array Index Out of Bounds

文章目录 简介什么是Array Index Out of BoundsArray Index Out of Bounds的常见原因如何检测和调试Array Index Out of Bounds解决Array Index Out of Bounds的最佳实践详细实例解析示例1&#xff1a;访问负索引示例2&#xff1a;访问超出上限的索引示例3&#xff1a;循环边界…

一颗B+树可以存储多少数据?

一、前言 这个问题&#xff0c;非常经典&#xff0c;考察的点很多&#xff1a; 比如&#xff1a; 1、操作系统存储的单元&#xff0c;毕竟mysql也是运行在操作系统之上的应用。 2、B树是针对Mysql的InnoDB存储引擎&#xff0c;所以要理解InnoDb的最小存储单元&#xff0c;页&…

【Arduino】实验使用ESP32单片机根据光线变化控制LED小灯开关(图文)

今天小飞鱼继续来实验ESP32的开发&#xff0c;这里使用关敏电阻来配合ESP32做一个我们平常接触比较多的根据光线变化开关灯的实验。当白天时有太阳光&#xff0c;则把小灯关闭&#xff1b;当光线不好或者黑天时&#xff0c;自动打开小灯。 int value;void setup() {pinMode(34…

java基于ssm+jsp 美食推荐管理系统

1前台首页功能模块 美食推荐管理系统&#xff0c;在系统首页可以查看首页、热门美食、美食教程、美食店铺、美食社区、美食资讯、我的、跳转到后台等内容&#xff0c;如图1所示。 图1前台首页功能界面图 用户注册&#xff0c;在注册页面可以填写用户名、密码、姓名、联系电话等…

什么是 vCPU?有什么作用

vCPU 是物理 CPU 的虚拟化版本&#xff0c;是云计算的基本组成部分。这些虚拟化计算单元的一大优势是其良好的可扩展性&#xff0c;这也是它们在云托管中发挥重要作用的原因。 vCPU 有什么作用? vCPU(虚拟中央处理器)是物理CPU的虚拟化变体。换句话说&#xff0c;vCPU 是虚拟机…

ctfshow 2023 愚人杯 web

easy_signin 观察url&#xff0c;发现base64 &#xff0c;进行解码&#xff0c;原来可以访问文件路径&#xff0c;那我们访问一下index.php ?imgaW5kZXgucGhw查看源代码发现还是base64 解码得到flag 被遗忘的反序列化 <?php# 当前目录中有一个txt文件哦 error_reporti…

计算机视觉 | 基于图像处理和边缘检测算法的黄豆计数实验

目录 一、实验原理二、实验步骤1. 图像读取与预处理2. 边缘检测3. 轮廓检测4. 标记轮廓序号 三、实验结果 Hi&#xff0c;大家好&#xff0c;我是半亩花海。 本实验旨在利用 Python 和 OpenCV 库&#xff0c;通过图像处理和边缘检测算法实现黄豆图像的自动识别和计数&#xff0…

MarkDown基础

一、MarkDown标题 1.使用和-表示一级标题 2.使用#、##、###、####、######、######表示一级至六级标题 一级标题 二级标题 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 二、MarkDown标题 1.Markdown 段落没有特殊的格式&#xff0c;直接编写文字就好&#xff0c;…

适耳贴合的气传导耳机,带来智能生活体验,塞那Z50耳夹耳机上手

现在大家几乎每天都会用到各种AI产品&#xff0c;蓝牙耳机也是我们必不可少的装备&#xff0c;最近我发现一款很好用的分体式气传导蓝牙耳机&#xff0c;它还带有一个具备AI功能的APP端&#xff0c;大大方便了我们日常的使用。这款sanag塞那Z50耳夹耳机我用过一段时间以后&…

共93本!全网最全Frontiers旗下期刊2022、2023版影响因子和分区对比完整版目录!

本周投稿推荐 SSCI • 1区&#xff0c;4.0-5.0&#xff08;无需返修&#xff0c;提交可录&#xff09; EI • 各领域沾边均可&#xff08;2天录用&#xff09; CNKI • 7天录用-检索&#xff08;急录友好&#xff09; SCI&EI • 4区生物医学类&#xff0c;0.1-0.5&…

postman测试接口使用

背景&#xff1a; 隔了一段时间没有用postman&#xff0c;有些忘记了&#xff0c;谨以此文来记录postman的使用&#xff0c;如有忘记就可以快速回忆 使用&#xff1a; 点击这个号&#xff0c;是创建接口页面 这里的复选框可供我们选择接口的rest方式 请求路径&#xff1a; …

qt 简单实验 一个可以向左侧拖拽缩放的矩形

1.概要 向左拖拽矩形&#xff0c;和向右拖拽不同&#xff0c;向右拖拽是增加宽度&#xff0c;向左拖拽是增加宽度的同时还要向左移动x的坐标。 2.代码 2.1 resizablerectangleleft.h #ifndef RESIZABLERECTANGLELEFT_H #define RESIZABLERECTANGLELEFT_H #include <QWid…