Вы можете сделать некоторое понимание списка и добавить любые столбцы, которые вы хотите text
см. Пример ниже (обратите внимание, я строю график в автономном режиме):
# data
np.random.seed(1)
labels = ['A', 'B', 'C']
N = 20
df = pd.DataFrame(index = range(N))
standardized_cols = []
for col in labels:
df[col] = np.random.randn(N)
standardized_colname = col + "_standardized"
standardized_cols.append(standardized_colname)
df[standardized_colname] = (df[col]-df[col].mean())/df[col].std()
c = KMeans(n_clusters=3, random_state=1).fit(df[standardized_cols]).labels_
plot:
import plotly as py
import plotly.graph_objs as go
trace = go.Scatter3d(
x=df.A_standardized,
y=df.B_standardized,
z=df.C_standardized,
mode='markers',
marker=dict(
size=5,
color=c,
colorscale='Viridis',
),
name= 'test',
# list comprehension to add text on hover
text= [f"A: {a}<br>B: {b}<br>C: {c}" for a,b,c in list(zip(df['A'], df['B'], df['C']))],
# if you do not want to display x,y,z
# hoverinfo='text'
)
layout = dict(title = 'TEST',)
data = [trace]
fig = dict(data=data, layout=layout)
py.offline.plot(fig, filename = 'stackTest.html')
Вы можете изменить понимание списка, чтобы отобразить все, что вы хотите
, если вы не хотите отображать x,y,z
, затем добавьте hoverinfo='text'