Tim*_*ood 8 python size marker plotly scatter3d
我有一个数据框df:
x y z ... colours marker_size marker_opacity
test1 0.118709 0.219099 -0.024387 ... red 100 0.5
test2 -0.344873 -0.401508 0.169995 ... blue 100 0.5
test3 -0.226923 0.021078 0.400358 ... red 100 0.5
test4 0.085421 0.098442 -0.588749 ... purple 100 0.5
test5 0.367666 0.062889 0.042783 ... green 100 0.5
Run Code Online (Sandbox Code Playgroud)
我试图用这样的情节来绘制它:
fig = px.scatter_3d(df,
x='x', y='y', z = 'z',
color='labels',
hover_name = df.index,
opacity = 0.5,
size = 'marker_size')
fig.write_html(file_name)
Run Code Online (Sandbox Code Playgroud)
当我打开时file_name,一切都很好,但我的积分太大了。当我更改'marker_size'my 的列df时,没有任何变化(我尝试过 0.1、1、10、100...)。
为什么是这样?
我也尝试过:
参数:
size = 1:
结果:
ValueError: Value of 'size' is not the name of a column in 'data_frame'. Expected one of ['x', 'y', 'z', 'labels', 'colours', 'marker_size', 'marker_opacity'] but received: 1
参数:
size = [1]*len(df):
结果:与使用'marker_size' df色谱柱没有区别
ves*_*and 16
如果您希望增加所有痕迹的标记大小,只需使用:
fig.update_traces(marker_size = 12)
Run Code Online (Sandbox Code Playgroud)
size的属性不能px.scatter_3d让您直接指定标记的大小。而是让您向散点图添加第四个维度,表示另一个变量的变化大小。
Run Code Online (Sandbox Code Playgroud)size: str or int or Series or array-like Either a name of a column in `data_frame`, or a pandas Series or array_like object. Values from this column or array_like are used to assign mark sizes.
1将值从 更改为10或 的原因是您似乎同时100更改了所有值:df['marker_size']
为了使这样的赋值生效,您需要在 中拥有一个变量而不是常量df['marker_size']。您可以通过以下代码片段仔细了解这些事情是如何工作的:
import plotly.express as px
df = px.data.iris()
fig = px.scatter_3d(df, x='sepal_length', y='sepal_width', z='petal_width',
color='species',
size = 'petal_length'
)
fig.show()
Run Code Online (Sandbox Code Playgroud)
在这里您可以看到该size属性按预期工作,因为您的标记将具有如下定义的不同大小df['petal_length]: