python - 交互式 Altair 图中的条形宽度

标签 python data-visualization altair

如何使条形与一整天一样宽?现在,条形图更像是划分一天的开始的线。我是否从条形标记切换到矩形标记?我会玩带秤吗?或者我是否在不修改数据的情况下强制分箱?

现在条形图太细了。因为图形是交互式的,所以我无法设置条形宽度;宽度与缩放无关。缩小得太远,条形开始重叠。放大得太远,它们看起来又像线条了。

天在 x 轴上。标签不应该改变。该图是交互式的,其宽度是固定的。条形之间的空白应反射(reflect)缺失的天数,而不是用条形填充。

import pandas as pd
import numpy as np
import altair as alt

c1 = np.random.randint(1,6, size=15)
c2 = pd.date_range(start="2021-01-01",end="2021-01-15")
df = pd.DataFrame({"day": c2, "value": c1})
df = df.drop([2, 5,6,7,13])
alt.Chart(df).mark_bar().encode(alt.X("day:T"), alt.Y("value")).interactive(bind_y=False).properties(width=800)

example of thin bars

理想情况下,当条形图填满一整天时,日期标记应位于条形图的中央(而不是在开始处)。

最佳答案

您可以使用 timeUnit 来做到这一点用 ordinal encoding .即替换

alt.X("day:T")

alt.X("date(day):O")

结果是这样的: enter image description here

根据您想要的轴标签,您可以改用 monthdateyearmonthdate 时间单位。

如果你希望轴仍然是交互的,序号编码不是一个选项。在这种情况下,另一种选择是使用 XX2 编码指定条形宽度,并使用计算转换来定义限制。例如:

alt.Chart(df).transform_calculate(
    day = "toDate(datum.day)",
    start = "datum.day - 12 * 60 * 60 * 1000",  # -12 hours in milliseconds
    end = "datum.day + 12 * 60 * 60 * 1000",    # +12 hours in milliseconds
).mark_bar().encode(
    alt.X("start:T"),
    alt.X2("end:T"),
    alt.Y("value")
).interactive(bind_y=False).properties(width=800)

enter image description here

关于python - 交互式 Altair 图中的条形宽度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65804117/

相关文章:

python - 在 Altair 中向分层图表添加图例

javascript - 使用特定列编码阻止图表显示的 Altair Javascript 错误

python - Amazon S3 boto - 如何删除文件夹?

python - 如何修复 Django 1.9 中的弃用警告

r - 图中每个点的高度值

python - 在 Pandas 图中标记内插的 NaN 点

Python - 将整数列表拆分为正数和负数

python - 将秒转换为分钟、小时和天的函数

python - python 中 matlibplot 中散点图的缩放轴

python - 使用 Altair 的 y 双轴