Skip to content

SCATTER3D

Create a Plotly 3D Scatter visualization for a given input DataContainer. Params: default : OrderedTriple|DataFrame the DataContainer to be visualized Returns: out : Plotly the DataContainer containing the Plotly 3D Scatter visualization
Python Code
import plotly.express as px
import plotly.graph_objects as go
from flojoy import DataFrame, OrderedTriple, Plotly, flojoy
from blocks.DATA.VISUALIZATION.template import plot_layout


@flojoy
def SCATTER3D(default: OrderedTriple | DataFrame) -> Plotly:
    """Create a Plotly 3D Scatter visualization for a given input DataContainer.

    Parameters
    ----------
    default : OrderedTriple|DataFrame
        the DataContainer to be visualized

    Returns
    -------
    Plotly
        the DataContainer containing the Plotly 3D Scatter visualization
    """

    layout = plot_layout(title="SCATTER3D")
    fig = go.Figure(layout=layout)
    match default:
        case OrderedTriple():
            x = default.x
            if isinstance(default.x, dict):
                dict_keys = list(default.x.keys())
                x = default.x[dict_keys[0]]
            y = default.y
            z = default.z
            fig.add_trace(go.Scatter3d(x=x, y=y, z=z, mode="markers"))
        case DataFrame():
            df = default.m
            if len(df.columns) < 3:
                raise ValueError(
                    "DataFrame must have at least 3 columns for x, y, and z coordinates."
                )

            x_column = df.columns[0]
            y_column = df.columns[1]
            z_column = df.columns[2]

            fig = px.scatter_3d(df, x=x_column, y=y_column, z=z_column, color=z_column)

    return Plotly(fig=fig)

Find this Flojoy Block on GitHub

Example

Having problems with this example app? Join our Discord community and we will help you out!
React Flow mini map

In this example we’re simulating data from PLOTLY_DATASET and DF_2_ORDEREDTRIPLE and visualizing them with SCATTER3D node which creates a Plotly Scatter 3D visualization for the input node.