- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望能够做这样的事情-
注意:您看到的水平线不在 y=0,而是在 y=1
但使用 color
或 fill
编码和 condition
在面积图中并不真正起作用。
我得到的最接近的是在 mark_area
中使用 yOffset
(完美值的命中和试验),但最大的问题是 y 轴保持不变因此图表实际上变为无效。
示例:
(忽略水平连接的图表 - 它只是为了能够为 yOffset
提供一个好的值,因为 y 轴根本没有移动。)
import pandas as pd
data = pd.DataFrame({'date': pd.date_range(start='1/1/2018', end='1/11/2018'), 'stock': [0.1, 0.3, 0.9, 1, 1.5, 1.2, 0.8, 1.1, 0.4, 0.8, 1.6]})
left = alt.Chart(data).mark_area().encode(
x='date:T',
y='stock:Q',
fill = alt.condition(alt.datum.stock<1, alt.value('grey'), alt.value('red'))
)
right = alt.Chart(data).mark_area(yOffset=190, ).encode(
x='date:T',
y='stock:Q',
fill = alt.condition(alt.datum.stock<1, alt.value('grey'), alt.value('red'))
)
left | right
有没有办法在 Altair 中做这样的事情?
编辑 1:
我尝试了这个 post 的想法这有点相似,但它并没有像我想象的那样工作 -
trial1 = alt.Chart(data).mark_area().transform_calculate(below=alt.datum.stock<=1).encode(
x='date:T',
y=alt.Y('stock:Q'),
color = 'below:N'
)
trial2 = alt.Chart(data).mark_area().transform_calculate(below=alt.datum.stock<=1).encode(
x='date:T',
y=alt.Y('stock:Q', impute={'value': 1}),
color = 'below:N'
)
trial1|trial2
最佳答案
您可以通过 y2
参数提供第二个 y 编码来将基线定义为 1。将这种方法用于条形图相对简单:
import pandas as pd
import altair as alt
data = pd.DataFrame(
{'date': pd.date_range(start='1/1/2018', end='1/11/2018'),
'stock': [0.1, 0.3, 0.9, 1, 1.5, 1.2, 0.8, 1.1, 0.4, 0.8, 1.6],
'baseline': [1]*11})
# You could also set the bar width instead of binning
alt.Chart(data).mark_bar().encode(
x=alt.X('monthdate(date):T'),
y='stock:Q',
y2='baseline',
color = alt.condition(alt.datum.stock < 1, alt.value('grey'), alt.value('red')))
这很有效,因为条形图是独立的图形元素,因此它们将单独着色。面积图是一个单一的图形元素,因此只对第一个股票值进行条件比较,然后整个区域都涂上这种颜色。为了获得不同的颜色,我们需要按照您链接的答案对其进行分组,将该区域分成多个标记(这也适用于条形图)。您可以通过事先在数据框中创建一个分组列或通过 transform_calculate
来执行此操作。
(alt.Chart(data.reset_index()).mark_area().encode(
x=alt.X('date:T'),
y=alt.Y('stock:Q', impute={'value': 1}),
y2='baseline',
color=alt.Color('negative:N', scale=alt.Scale(range=['red', 'grey'])))
.transform_calculate(negative='datum.stock < 1'))
为什么点之间有重叠?这样做的原因是数据稀疏,并且默认的插值方法是区域和线标记的“线性”。如果将其更改为 mark_area(interpolate='step')
,则区域之间的边界会很清晰:
要在保持其形状的同时实现基线周围区域标记的急剧过渡,数据需要具有更高的分辨率。借用您链接的答案,您可以看到当数据稀疏时,那里的区域也会重叠:
import altair as alt
import pandas as pd
import numpy as np
x = np.linspace(2, 4, 4)
df = pd.DataFrame({'x': x, 'y': np.sin(x)})
(alt.Chart(df).mark_area().encode(
x='x',
y=alt.Y('y', impute={'value': 0}),
color='negative:N')
.transform_calculate(negative='datum.y < 0'))
如果我们将点数增加十倍 (x = np.linspace(2, 4, 40)
),随着插值发生在空间更近的点之间(改变插值),过渡变得更清晰从线性到单调,在保持形状的同时也可能有所帮助。
要提高时间序列数据的分辨率,您可以使用 pandas resample
和 interpolate
方法进行上采样。做这样的事情时要担心的是,如果你以有意义的方式人为地改变了你的数据。我发现问问自己操作是否会改变您对数据得出的结论很有用。
(alt.Chart(data.set_index('date').resample('1h').interpolate().reset_index()).mark_area().encode(
x=alt.X('date:T'),
y=alt.Y('stock:Q', impute={'value': 1}),
y2='baseline',
color=alt.Color('negative:N', scale=alt.Scale(range=['red', 'grey'])))
.transform_calculate(negative='datum.stock < 1'))
在这里,我们对每小时数据点进行上采样,并在原始点之间进行线性插值。对我而言,这不会改变我从研究绘图中得出的结论,因为线性插值保留了区域的 block 状外观,因此我们不会人为地使数据看起来平滑。我想到的唯一缺点是我们确实向 Altair 发送了不必要的数据量,您可以使用 Altair 中的转换来执行插值,但我不确定如何在我的脑海中。
关于python - 如何在 Altair 中正确地将区域图中的基线移动到特定的 y 位置并相应地更改填充颜色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63659737/
我在 Web 应用程序中尝试了一些字节码操作,到目前为止,效果很好。现在我需要在代码中的某些特定位置注入(inject)一些字节代码。我用 switch 语句和 method.inserAt(); 尝
我正在尝试对数组中的对象值求和,然后计算每个值相对于总数的百分比。 这里是数组: [ { "ratiototale": [ [ { "0":
我在接口(interface)中有以下方法.. Task> SearchAsync(TU searchOptions); 效果很好。 现在我正在尝试进行单元测试以测试何时出现问题 - 代码会抛出异常。
我似乎无法让 reveal 开始工作,我已经严格遵守所有内容,添加 modernizr,添加插件,添加 css(reveal 显然包含在 foundation 中),在开始时初始化 foundatio
我正在尝试移植 raspberrypi's userspace 的位从 C 到 golang 的代码,我遇到了一个涉及 ioctl() 的程序。 我在执行 C 代码时遇到了问题 #define MAJ
我一直在尝试用纯 Java 制作一个简单的游戏,但在绘图时遇到了问题。我正在尝试保持相对较高的帧速率,但是 JFrame.repaint() 不能被“强制”并且只是在下一个可用机会重绘帧的请求这一事实
给定一个字符串 "2*(i+j) = 20 我想返回 ((lambda x: x >= 20), ['i']) 我可以然后直接提供给 constraint。 最佳答案 您正在寻找 eval 的替代方法
我对改进我的 javascript 代码以使其成为正确的 OOP 很感兴趣....目前我倾向于做这样的事情: jQuery(document).ready(function () { Page
我有一个调用两个动画 Action 的事件监听器。不幸的是,它们的开始有少量错开(例如,函数中的第一个首先开始)。 有谁知道正确同步它们的方法吗? 这是我的代码: $("#nav ul li a").
我只需要检查目录是否存在!但是,如果目录是“E:\Test”,其中 E: 是 CD/DVD 驱动器,并且上面没有插入磁盘,我会看到以下 Delphi 和 Windows 问题。 第一种方法: func
同样的问题: https://stackoverflow.com/questions/11294207/exchange-web-services-argumentexception-using-my
如果您跳转到 this question 中的第一个答案你会看到他使用 Employee.prototype = new Person(); 将 Person.prototype 继承到 Employ
我需要知道如何正确地遍历元素的 ArrayList 并计算元素在列表中出现的次数,而无需事先知道该元素。我尝试了几种方法并且有一种目前有效,但我觉得它很丑陋且不合适。 为了更深入地解释,我有一个 ja
我有一个用 Python 编写的(非常基本但工作完美的)AWS lambda 函数,但是它具有嵌入式凭证以连接到:1)外部网络服务2) DynamoDB 表。 该函数的作用相当基本:它针对服务发布登录
我很好奇 Tornado 推荐的查询 Redis(或任何数据库)的方法是什么。 我见过一些像 https://gist.github.com/357306 这样的例子但他们似乎都在使用对 redis
这更像是一个“我做得对吗”的问题。 快速背景故事:我已经构建了一个 gradle 插件(在一个独立的 gradle/groovy 项目中)。我在另一个 java 项目中使用它。客户项目通过以下方式引用
在我的代码中,我有: function handleMessage() { const twilio = require('twilio')(process.env.TWILIO_ACCOUNT_
我正在努力在 Linux 中刷新嵌入式设备的先前 ROM 转储。我以前的转储包含 oob 数据。我是用nandwrite -n -N -o/dev/mtd0 backup.bin写的,然后再做一次RO
我正在尝试使用 go 为 react-router 提供服务,我已经做到了,但我遇到了麻烦,我认为我做的方式不正确,或者不完整。我正在使用 Mux。我遇到的麻烦是当我按下 时在我的应用程序中,它正确
我正在尝试 promise JSON.parse 方法,但不幸的是没有任何运气。这是我的尝试: Promise.promisify(JSON.parse, JSON)(data).then((resu
我是一名优秀的程序员,十分优秀!