Data Visualization and D3.js 笔记(1)
课程地址: https://classroom.udacity.com/courses/ud507
什么是数据可视化?
- 高效传达一个故事/概念,探索数据的pattern
- 通过颜色、尺寸、形式在视觉上表示基础数据和storytelling,然后得到一些发现
数据可视化是一种从值到图像的映射,将结构化的数据信息转化为更易理解的视觉图像。
什么是好的数据可视化?[by Cole Nussbaumer]
- 对内容有透彻的理解,知道谁是观众、他们想得到什么?
- 数据展示,选择恰当的图像类型
- 排除无效信息,删除不会为图像增加价值的内容。降低认知负担,突出数据
- 通过颜色、尺寸、布局等元素吸引观众注意力,让他们知道哪里是重点
- 故事叙述。好的数据可视化会让本身成为故事或叙述的关键点
数据科学与数据可视化

(by Ben Fry)
这是一个非线性迭代,在过程中会不断回溯前一步骤,或从新数据得到新结果进行合并。
EDA vs. Data Visualization
EDA, Exploratory Data Analysis, is whatever happened between you and your data when you are not trying to proof anything to anyone. But Data Visualization cares about it.
Amscombe 四重奏
Anscombe’s quartet是指四组基本统计特征(均值、方差、相关系数、最优拟合线)一致的数据,由他们绘制出来的图形截然不同。
说明分析数据前先绘制图表的重要性,以及离群值对统计的影响。
Data && Data Types
- 值数据 Quantitative Data
- 离散
- 连续
- 分类数据 Categorical Data (表示特性,可以用数值表示,但是没有数学意义)
- 定类数据 Nominal
- 对数据进行标注和分类的一种方法
- 有序数据 Ordinal
- 定类数据 Nominal
- 时序数据 Time Series Data
- 经过长时间重复观测得到的数据集合
Visual Encoding
Visual Encoding is mapping data to display elements.
- Position
平面内可对x和y两个变量进行编码
人眼对三维很难迅速感知 - Retinal Variables 视网膜变量
- For Ordered Data
- size
- orientation
- color saturation
- For Nominal Data
- color hue
- shape
- texture
- For Ordered Data
- Animation
not a Visual Encoding, but encodes some information- time 用帧来代表时间
大专栏 Data Visualization and D3.js 笔记(1)l Encoding">Rankings of Visual Encoding

D3.js

D3: Data Driven Document
- Data: csv / json
- Driven: 将csv / json 数据与SVG元素结合 (DOM)
- Document: HTML, CSS, JS, SVG
DOM 与 HTML
浏览器存储两种Web页面/视图
从服务器返回的初始源
1
2
3
4
5
6
7<html>
<head>
</head>
<body>
<svg>
</body>
</html>解析的DOM对象
- DOM 是一个规范,为HTML和XML文档规定了常见的编程接口
- 在页面被加载的时候逐步解析
- 通过JavaScript API访问
将HTML转为DOM
- 用户发出访问某一URL的请求
- 浏览器向服务器发送请求
- 浏览器收到服务器响应,即HTML
- 浏览器开始处理HTML文件
- 遇到一个标记,如
<html>,浏览器会发出一个token,startTag: htmlstartTag:headmetalink - 同时会消耗这些token, 生成节点对象,并建立联系
- DOM树被生成

有趣的图表们
斜率图 Slope Graph
用斜率代表方向和变化量,可以进行group之间的比较
小多组图 Small Multiples
利用相同的布局,可以进行
- 数据
- 数据组
之间的比较
一些链接
- https://charts.animateddata.co.uk/uktemperaturelines/
- http://www.storytellingwithdata.com/blog/2014/03/more-on-slopegraphs
- https://www.youtube.com/watch?v=jbkSRLYSojo
- https://www.targetprocess.com/articles/visual-encoding/
Data Visualization and D3.js 笔记(1)的更多相关文章
- D3 & Data Visualization in Ext JS
通过适配器可以在ExtJs中轻松的集成D3的展示能力 http://video.sencha.com/watch/zvUjnFJ91xVvuwdTh2zjqP?mkt_tok=eyJpIjoiWm1a ...
- 精通D3.js笔记
DOM常用属性 innerHTML: 元素标签内部的文本. innerText outerHTML outerText nodeName: 节点名称 parentNode: 父节点 nextSibli ...
- Python equivalent of D3.js
http://brandonrose.org/ Python equivalent of D3.js Ask Question Asked 7 years, 1 month ago Act ...
- d3.js:数据可视化利器之快速入门
hello,data! 在进入d3.js之前,我们先用一个小例子回顾一下将数据可视化的基本流程. 任务 用横向柱状图来直观显示以下数据: var data = [10,15,23,78,57,29,3 ...
- D3.js & Data Visualization & SVG
D3.js & Data Visualization & SVG https://davidwalsh.name/learning-d3 // import {scaleLinear} ...
- d3.js读书笔记-1
d3.js入门 d3入门 D3是一个强大的数据可视化工具,它是基于Javascript库的,用于创建数据可视化图形.在生成可视化图形的过程中,需要以下几步: 把数据加载到浏览器的内存空间: 把数据绑定 ...
- 【 D3.js 选择集与数据详解 — 2 】 使用data()绑定数据
D3 中绑定数据大多是由 data() 函数来完成的,它是怎样工作的,它与 datum() 有什么区别呢? data()函数能够将数组各项分别绑定到各元素上,而且能够设置绑定的规则.data()还能够 ...
- Data Visualization 课程 笔记1
对数据可视化比较有兴趣,因此最近在看coursera上伊利诺伊大学香槟分校的数据可视化课程,做了一些笔记. 1. 定义 Data visualization is a high bandwidth c ...
- 学习笔记之Data Visualization
Data visualization - Wikipedia https://en.wikipedia.org/wiki/Data_visualization Data visualization o ...
随机推荐
- SpringBoot项目示例
一.准备工作: 环境及工具:Eclipse+JDK8+Maven+SpringBoot 二.源码: 1.项目架构: 2.引入pom.xml <project ...
- tensorflow2使用中的一些问题
from tensorflow import keras import tensorflow as tf import numpy as np print(tf.__name__,tf.__versi ...
- 了解SSL证书从HTTPS开始 开发者绕不开的“劫”
微信小程序上线已经有很长一段时间了,而开发者在接入小程序的过程中,会遇到一些问题,例如小程序要求必须通过HTTPS完成服务端通信,开发者需搭建HTTPS服务,进行 SSL 证书申请.部署,完成HTTP ...
- PyTorch基础——词向量(Word Vector)技术
一.介绍 内容 将接触现代 NLP 技术的基础:词向量技术. 第一个是构建一个简单的 N-Gram 语言模型,它可以根据 N 个历史词汇预测下一个单词,从而得到每一个单词的向量表示. 第二个将接触到现 ...
- MyBatis从入门到精通(第4章):MyBatis动态SQL【if、choose 和 where、set、trim】
(第4章):MyBatis动态SQL[if.choose 和 where.set.trim] MyBatis 的强大特性之一便是它的动态 SQL.MyBatis 3.4.6版本采用了功能强大的OGNL ...
- 2020 CCPC Wannafly Winter Camp Day1-F-乘法
题目传送门 sol:二分答案$K$,算大于$K$的乘积有多少个.关键在于怎么算这个个数,官方题解上给出的复杂度是$O(nlogn)$,那么计算个数的复杂度是$O(n)$的.感觉写着有点困难,自己写了一 ...
- Pay Back(模拟)
链接:https://ac.nowcoder.com/acm/contest/1086/C 题目描述 "Never a borrower nor a lender be." O h ...
- HttpServletReqeust、HttpServletResponse
HttpServletRequest:一次来自客户端的请求的相关信息 请求行 request.getMethod() 获取http请求方式 request.getR ...
- DOM(Document Object Model)
DOM(Document Object Model): 结点的概念:整个文档就是由层次不同的多个节点组成,可以说结点代表了全部内容. 结点类型 1.元素结点 对于元素结点的n ...
- 如何使用jQuery给asp.net的TextBox取值和赋值
解决办法: 可以在控件中先设置属性ClientInstandName的值和ID的值一样,再使用$("#ID").val("12345")