如何解决处理 python Altair 工具提示文本中的“空”值
我有一个包含三列(“时间”、“实际值”、“预测”)的 Pandas 数据集。 我正在尝试使用 python 中的 altair 包在同一图中绘制两条线:
-Actual Value vs Time
-Prediction vs Time
在部分数据集中,我在“实际价格”和“预测”列中有空值 (np.nan)。
当我添加工具提示时,我在我拥有 np.nan 的部分中得到“null”作为文本:
Time : August 30,2018
Actual Value : null
Prediction : 150
我想将工具提示中的文本更改为自定义文本(例如:“不可用”)。
Time : August 30,2018
Actual Value : Not Available
Prediction : 150
data = {'Time': pd.date_range(start='1/1/2018',periods=8,freq='M'),'Actual Value': [100,150,200,120,180,110,np.NaN],'Prediction' : [np.NaN,140,160,150]}
df = pd.DataFrame (data)
## altair Plots
base = alt.Chart(df).transform_calculate(
line1="'Actual Value'",line2="'Prediction'",).properties(
height=360,width = 800
)
scale = alt.Scale(domain=["Actual Value","Prediction"],range=['blue','orange'])
line1 = base.mark_line(opacity=0.8,color='blue').encode(
x=alt.X('Time:T',title='Time'),y=alt.Y('Actual Value:Q',axis = alt.Axis(title="Price")),color = alt.Color('line1:N',scale=scale,title=' '),)
line2 = base.mark_line(color='orange').encode(
x=alt.X('Time:T',y=alt.Y('Prediction:Q',color = alt.Color('line2:N',)
# Tooltip Function
def createtooltip():
"""
This function creates a tooltip containing the date,and prices displayed upon hover
"""
hover = alt.selection_single(
fields=["Time"],nearest=True,on="mouSEOver",empty="none",clear="mouSEOut",)
tooltips = alt.Chart(df).mark_rule(strokeWidth=0.5,color="black",strokeDash=[4,2]).encode(
x='Time',opacity=alt.condition(hover,alt.value(1),alt.value(0)),tooltip=["Time",alt.Tooltip("Actual Value:N",title='Actual Value'),alt.Tooltip("Prediction:N",title='Prediction')]
).add_selection(hover)
return tooltips
tooltips = createtooltip()
alt.layer(line1+line2,tooltips).interactive()
解决方法
您可以使用 calculate transform 执行此操作。例如:
tooltips = alt.Chart(df).transform_calculate(
P="isValid(datum.Prediction) ? datum.Prediction : 'Undefined'",A="isValid(datum['Actual Value']) ? datum['Actual Value'] : 'Undefined'"
).mark_rule(strokeWidth=0.5,color="black",strokeDash=[4,2]).encode(
x='Time',opacity=alt.condition(hover,alt.value(1),alt.value(0)),tooltip=["Time",alt.Tooltip("A:N",title='Actual Value'),alt.Tooltip("P:N",title='Prediction')]
).add_selection(hover)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。