大数据可视化实验三——数据可视化工具使用

目录

一、实验目的... 1

二、实验环境... 1

三、实验内容... 1

1. 下载并安装Tableau软件.. 1

2. 使用HTML5绘制Canvas图形.. 2

3. 使用HTML5编写SVG 图形... 5

4. 使用R 语言编写可视化实例.. 7

四、总结与心得体会... 7

五、思考问题... 8

一、实验目的

1)了解数据可视化工具,下载并安装可视化工具

2)掌握数据可视化的主流编程语言,能使用编程语言开发简单的可视化作品

二、实验环境

硬件:微型图像处理系统,

包括:主机, PC机;

操作系统:Windows 11        

应用软件:Jupyter Notebook, pycharm, Tableau

数字图像处理软件:Excel/Python

三、实验内容

1. 下载并安装Tableau软件

Tableau软件已下载成功,软件界面如下所示:

2. 使用HTML5绘制Canvas图形

在pycharm中编辑如下代码进行Canvas图形的绘制,编写了以下代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>我的html绘制Canvas</title>
</head>
<body>
<canvas id="myCanvas" width="200" height="200" style="border: solid 1px red;">
    你的浏览器不支持Canvas,建议使用最新版Chrome
</canvas>
<script>
    var c = document.getElementById("myCanvas");
    var ctx = c.getContext("2d");
    // 绘制一个圆
    ctx
.beginPath();
    ctx.arc(100, 75, 40, 0, 2*Math.PI);
    ctx.stroke();
    // 绘制一个填充矩形,改变颜色为浅红色
    ctx
.fillStyle = 'lightcoral'; // 浅红色
    ctx
.fillRect(30, 30, 60, 60);  // 修改位置和大小
    //
绘制另一个填充矩形,颜色保持为浅红色
    ctx
.fillRect(140, 30, 60, 60); // 修改位置和大小
    //
绘制两个矩形边框,位置和大小根据填充矩形调整
    ctx
.strokeRect(30, 30, 60, 60);
    ctx.strokeRect(140, 30, 60, 60);
    // 绘制一条直线
    ctx
.moveTo(30, 30);
    ctx.lineTo(170, 170);
    ctx.stroke();
    var text = "我的canvas";
    // 设置文本的字体样式和大小
    ctx
.font = "16px Arial";
    // 设置文本颜色
    ctx
.fillStyle = 'darkblue'; // 文本颜色改为深蓝色
    //
设置文本对齐方式
    ctx
.textAlign = "center";
    // 设置文本的基线对齐方式
    ctx
.textBaseline = "middle";
    // 计算文本的宽度
   
var textWidth = ctx.measureText(text).width;
    // 设置文本绘制的起始点位置
   
var x = 95 ;
    var y = 180;
    // 使用fillText()方法填充(实心)文本
    ctx
.fillText(text, x, y);
</script>
</body>
</html>

整体上,这段代码在canvas上绘制了一个圆、两条直线、两个填充矩形和两个矩形边框,并在画布中心绘制了文本。通过调整参数,你可以改变这些图形的位置、大小和颜色。

  1. <!DOCTYPE html>:声明文档类型,告诉浏览器这是一个HTML5文档。
  2. <html lang="en">:根元素,定义了整个文档的语言为英语。
  3. <head>:包含了文档的元数据,如字符集声明和标题。
  4. <meta charset="UTF-8">:指定页面的字符编码为UTF-8,这是一种广泛使用的字符编码。
  5. <title>我的html绘制Canvas</title>:定义了网页的标题,显示在浏览器的标签页上。
  6. <body>:包含了网页的所有内容,用户将在这里看到网页的主体。
  7. <canvas id="myCanvas" width="200" height="200" style="border: solid 1px red;">:创建了一个200x200像素的画布,并为其添加了红色的边框。id属性为"myCanvas",用于在JavaScript中引用这个元素。如果浏览器不支持<canvas>元素,将显示canvas后面的文本。
  8. <canvas>后面的文本是备选内容,用于那些不支持canvas的浏览器。推荐用户使用最新版的Chrome浏览器。
  9. <script>:内嵌的JavaScript代码块,用于操作canvas元素。
  10. var c = document.getElementById("myCanvas");:通过ID获取canvas元素。
  11. var ctx = c.getContext("2d");:获取canvas的2D绘图上下文,这是绘制图形所需的。
  12. 使用ctx.beginPath()开始一个新的路径。
  13. 使用ctx.arc(100, 75, 40, 0, 2*Math.PI)绘制一个圆,圆心位于(100, 75),半径为40,从0度到360度(即一个完整的圆)。
  14. 使用ctx.stroke()绘制当前路径的轮廓。
  15. 使用两个ctx.strokeRect()方法绘制两个矩形的边框,分别定义了矩形的位置和大小。
  16. 使用ctx.fillStyle = 'lightcoral';设置填充颜色为浅红色。
  17. 使用ctx.fillRect(30, 30, 60, 60);绘制一个填充矩形,定义了矩形的位置和大小。
  18. 另一个ctx.fillRect()方法绘制第二个填充矩形。
  19. ctx.moveTo(30, 30);和ctx.lineTo(170, 170);定义了一条从左上角到右下角的直线的起点和终点。
  20. 使用ctx.stroke()绘制直线。
  21. var text = "我的canvas图";定义了要绘制的文本内容。
  22. ctx.font = "16px Arial";设置文本的字体样式和大小。
  23. ctx.fillStyle = 'darkblue';设置文本的填充颜色为深蓝色。
  24. ctx.textAlign = "center";和ctx.textBaseline = "middle";设置文本的水平和垂直对齐方式。
  25. 使用ctx.measureText(text).width计算文本的宽度。
  26. 计算文本绘制的起始点位置,确保文本位于画布的中心。
  27. 使用ctx.fillText(text, x, y);在指定位置填充(绘制实心)文本。

运行结果如下:

3. 使用HTML5编写SVG 图形

编写SVG绘制html5代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Advanced SVG Example</title>
    <style>
        /* SVG中的文本添加样式 */
       
text {
            font-family: Arial, sans-serif;
            font-size: 12px;
        }
    </style>
</head>
<body>
    <!-- SVG 容器 -->
   
<svg width="400" height="400">
        <!-- 定义一个线性渐变 -->
       
<defs>
            <linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%">
                <stop offset="0%" style="stop-color:rgb(255,255,0);stop-opacity:1" />
                <stop offset="100%" style="stop-color:rgb(255,0,0);stop-opacity:1" />
            </linearGradient>
        </defs>
        <!-- 使用渐变填充绘制圆形 -->
       
<circle cx="100" cy="100" r="50" fill="url(#grad1)" />

        <!-- 绘制带箭头的直线 -->
       
<line x1="200" y1="100" x2="250" y2="150" stroke="black" stroke-width="2">
            <polygon points="250,150 255,155 245,155" fill="black" />
        </line>

        <!-- 绘制矩形 -->
       
<rect x="150" y="30" width="100" height="50" fill="blue" stroke="black" stroke-width="2" />

        <!-- 添加文字 -->
       
<text x="20" y="20">我的svg图形</text>
    </svg>
</body>
</html>

运行结果如下:

4. 使用R 语言编写可视化实例

编写R语言代码绘制散点图如下:

# 载入ggplot2包

library(ggplot2)

# 创建一个数据框,包含两组变量

data <- data.frame(

  x = 1:10,

  y = (1:10)^2

)

# 使用ggplot2创建散点图

ggplot(data, aes(x = x, y = y)) +  # 指定数据和映射关系

  geom_point() +  # 添加散点图层

  labs(title = "散点图示例", x = "X轴变量", y = "Y轴变量")  # 添加标题和坐标轴标签

# 显示图形

运行结果如下:

四、总结与心得体会

1.在pycharm中可以直接新建html5文件编辑html代码,好处是有错误提醒,也可以在文本文件中直接编写,然后将后缀改为html运行。

五、思考问题

大数据可视化还有哪些工具?都能实现相同的功能吗?

可视化的工具还有origin、C/C++语言和matlab等,基本的可视化功能都可以实现,但是上手难易程度不同,对不同的工作完成的方便程度也不同,针对不同问题可以采用不同的工具。

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

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

相关文章

C++-Linux工程管理

1 Makefile和CMake实践 1.1 Makefile 参考 简介&#xff1a; Makefile是一种用于自动化构建和管理程序的工具。它通常用于编译源代码、链接对象文件以生成可执行文件或库文件。Makefile以文本文件的形式存在&#xff0c;其中包含了一系列规则和指令&#xff0c;用于描述程序的…

python数据分析——seaborn绘图1

参考资料&#xff1a;活用pandas库 matplotlib库是python的和兴绘图工具&#xff0c;而seaborn基于matplotlib创建&#xff0c;它为绘制统计图提供了更高级的接口&#xff0c;使得只用少量代码就能生成更美观、更复杂的可视化效果。 seaborn库和pandas以及其他pydata库&#xf…

Go 阻塞

阻塞 在Go语言中&#xff0c;阻塞通常指的是一个goroutine&#xff08;轻量级线程&#xff09;在等待另一个goroutine完成操作&#xff08;如I/O操作、channel通信等&#xff09;时&#xff0c;暂时停止执行的现象。Go语言提供了多种同步和通信机制&#xff0c;可以用于实现阻…

数据赋能(86)——数据要素:管理核心框架

数据管理的核心框架是一个综合性的体系&#xff0c;旨在确保数据的有效利用、安全性以及合规性。这个框架主要包含了以下几个关键组成部分&#xff1a; 数据治理策略与目标&#xff1a;明确数据管理的整体战略和目标&#xff0c;包括数据价值的释放、数据资产地位的确定、多元…

OpenHarmony 实战开发——移植通信子系统

通信子系统目前涉及Wi-Fi和蓝牙适配&#xff0c;厂商应当根据芯片自身情况进行适配。 移植指导 Wi-Fi编译文件内容如下&#xff1a; 路径&#xff1a;“foundation/communication/wifi_lite/BUILD.gn” group("wifi") {deps [ "$ohos_board_adapter_dir/ha…

C++基础与深度解析 | 数组 | vector | string

文章目录 一、数组1.一维数组2.多维数组 二、vector三、string 一、数组 1.一维数组 在C中&#xff0c;数组用于存储具有相同类型和特定大小的元素集合。数组在内存中是连续存储的&#xff0c;并且支持通过索引快速访问元素。 数组的声明&#xff1a; 数组的声明指定了元素的…

前端人员如何理解进程和线程

进程和线程的概念&#xff1a; 进程和线程本质都是cpu工作过程的时间片。 进程可以理解为cpu在运行指令即加载保存上下文所要用的时间。也可以理解为一个应用程序运行的实例。 线程是进程中更小的单位&#xff0c;描述一段指令所需要的时间。 进程是资源分配的最小单位&#xf…

【数据结构】数组循环队列的实现

队列&#xff08;Queue&#xff09;是一种特殊的线性数据结构&#xff0c;它遵循FIFO&#xff08;First In First Out&#xff0c;先入先出&#xff09;的原则。队列只允许在表的前端&#xff08;front&#xff09;进行删除操作&#xff0c;而在表的后端&#xff08;rear&#…

MySQL中导出CSV格式数据 | Java处理CSV数据

1. 导出不带表头的CSV数据 SELECT dataid, recordfilename INTO OUTFILE /tmp/uk_callcenter_event3.csv FIELDS TERMINATED BY , LINES TERMINATED BY \n FROM table_name WHERE createtime > 2024-03-27 22:00:00 AND createtime < 2024-04-29 23:59:59 AND timehou…

使用selenium控制已经打开的浏览器,应该如何实现。

要使用Selenium控制一个已经打开的浏览器实例&#xff0c;你可以通过以下步骤实现&#xff0c;这里以Google Chrome浏览器为例&#xff1a; 步骤 1: 启动Chrome浏览器并启用远程调试 首先&#xff0c;你需要以远程调试模式启动Chrome浏览器。这可以通过在命令行中使用特定参数来…

python下载及安装

1、python下载地址&#xff1a; Python Releases for Windows | Python.orgThe official home of the Python Programming Languagehttps://www.python.org/downloads/windows/ 2、python安装 &#xff08;1&#xff09; 直接点击下载后的可执行文件.exe &#xff08;2&…

Spring Boot项目怎么集成Gitee登录

一、背景 现在的越来越多的项目&#xff0c;需要集成第三方系统进行登录。今天我们以Spring Boot项目集成Gitee为例&#xff0c;演示一下怎么使用Oauth2协议&#xff0c;集成第三方系统登录。 不了解oauth2的&#xff0c;可以看我之前的文章。Ouath2是怎么实现在第三方应用认…

MySQL创建储存过程函数

DDL CREATE TABLE student (id int(11) NOT NULL AUTO_INCREMENT COMMENT 学号,createDate datetime DEFAULT NULL COMMENT 创建时间,modifyDate datetime DEFAULT NULL COMMENT 修改时间,userName varchar(30) NOT NULL COMMENT 学生名称,pwd varchar(36) DEFAULT NULL COMME…

代码随想录算法训练营第五十二天

今日效率低下&#xff0c;努力把题做完。做快一点&#xff01;&#xff01;&#xff01; 300.最长递增子序列 class Solution { public:int lengthOfLIS(vector<int>& nums) {if (nums.size() 1) return 1;vector<int>dp(nums.size(),1);int result 0;for(i…

计算机毕业设计Python+Spark知识图谱课程推荐系统 课程预测系统 课程大数据 课程数据分析 课程大屏 mooc慕课推荐系统 大数据毕业设计

1 绪 论 1.1 课题研究背景 在线教育学习平台是学生用来进行校内或校外拓展课程学习的平台&#xff0c;平台需要具备在线视频观看&#xff0c;作业提交&#xff0c;形成性考核等功能。在学生学习的过程中&#xff0c;学校的管理者或负责教师需要了解学生的学习情况和学习状态&…

Spring STOMP-发送消息

如果你想要从应用程序的任何地方向连接的客户端发送消息&#xff0c;要怎么做&#xff1f;任何应用程序组件都可以向brokerChannel发送消息。要这样做&#xff0c;最简单方法是注入一个SimpMessagingTemplate并使用它来发送消息。通常&#xff0c;你会按类型注入它&#xff0c;…

WWW服务器搭建(2)——Apache服务器配置与管理

一、Apache简介 1.1 关于Apache Apache HTTP Server&#xff08;简称Apache&#xff09;是Apache软件基金会的一个开放源码的Web服务器&#xff0c;可以在大多数计算机操作系统中运行&#xff0c;由于其跨平台和安全性被广泛使用&#xff0c;是最流行的Web服务器端软件之一。…

01-02-5

1、单链表中按位置查找 a.原理 通过传递的位置&#xff0c;返回该位置对应的地址&#xff0c;放到主函数定义的指针变量中。 我们认为位置从&#xff1a;有数据的节点开始计数 即如下结构&#xff1a; 查找位置&#xff0c;就是返回该位置对应的空间地址。 b.代码说明 Ⅰ…

H5嵌入原生----兼容安卓与ios

主要分UI展示&#xff0c;键盘&#xff0c;输入框等等。解决bug最苦恼的问题不是没有解决方案&#xff0c;而是你没有找到真正的原因。再就是现象难以重现&#xff0c;每次都要发布代码&#xff0c;然后到手机app中去测试&#xff0c;模拟。这些地方会耗费大量的精力。 一、UI…

【软设】常见易错题汇总

目录 计算机系统基础 程序语言基础 数据结构 算法设计与分析 计算机网络与信息安全 软件工程基础 开发方法&#xff08;结构化与面向对象&#xff09; 数据库 操作系统 知识产权相关的法律法规 &#x1f92f;&#x1f92f;&#x1f92f;&#x1f92f;&#x1f92f;&#x1f9…