[英]To show B(Billion) instead of G(Giga) in altair charts python
[英]B (billions) instead of G (giga) in python plotly customdata [SI prefix d3]
我經歷過這個, 這個和其他一些類似的帖子。 他們都用javascript給出了我無法移植到python的解決方案。 幫助將不勝感激。
當我將一個值傳遞給足夠大到 10 億的customdata
,它將符號顯示為 G(表示千兆)而不是 B,而 plotly 默認為 B,可以在圖像中看到比較。 有沒有辦法使用 B 而不是 G?
import pandas as pd
import plotly.express as px
df = pd.DataFrame({'x':[500,3000,50000,100000,7000000,80000000,400000000,9000000000]})
more_data = [100,3000,50000,600000,2000000,90000000,500000000,3000000000]
fig = px.line(df, log_y=True)
fig.update_traces(mode='lines+markers',
customdata=more_data,
hovertemplate='%{y}<br>%{customdata:,.1s}')
這不會是有史以來最優雅的解決方案,但它可以解決您的問題。 如果您仔細查看您的繪圖,您在索引 1 上也有問題,其中超量數據為3000<br>3k
。
所以我實際上是在明確地編寫懸停數據。 我們將需要這里的函數human_format
。
import pandas as pd
import plotly.express as px
df = pd.DataFrame({'x': [500,3000,50000,100000,7000000,80000000,400_000_000,9_000_000_000],
'more_data': [100,3000,50000,600000,2000000,90000000,500000000,3_000_000_000]})
def human_format(num):
num = float('{:.3g}'.format(num))
magnitude = 0
while abs(num) >= 1000:
magnitude += 1
num /= 1000.0
return '{}{}'.format('{:f}'.format(num).rstrip('0').rstrip('.'),
['', 'K', 'M', 'B', 'T'][magnitude])
df["hover_data"] = df.apply(lambda r:
f"{human_format(r['x'])}<br>{human_format(r['more_data'])}",
axis=1)
fig = px.line(df,
y="x", log_y=True)
fig.update_traces(mode='lines+markers',
customdata=df['hover_data'],
hovertemplate='%{customdata}')
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.