同一行的不同标记颜色
Different marker colors for the same line
我正在尝试使用 plotly 和 dash 为 webapp 创建一个简单的折线图。我想要一条连接两点的线。我想要一个点是红色的,另一个是绿色的。这是我目前拥有的:
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.graph_objs as go
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets = external_stylesheets)
graph = dcc.Graph(figure = {
'data' : [
go.Scatter(x = [1,4], y = [2,3], mode = 'lines+markers', opacity = 0.7, marker = {
'size' : 15,
'line' : {'width' : 0.5, 'color' : 'black'}
})
]
})
app.layout = html.Div([graph])
if __name__ == '__main__':
app.run_server(debug = False)
我运行在 Jupyter notebook 中使用所有最新的软件包来编写此代码。
如果我 运行 这段代码,我会得到我想要的线图,但两个点都是蓝色的。我希望 (1, 2) 对应的点为红色,(4, 3) 对应的点为绿色。我该怎么做呢?
提前致谢!
我认为这个问题的公认解决方案是在图形数据中包含 3 个不同的 go.scatter()
对象。一个用于线条,一个用于每个标记。您的应用最终会看起来像这样:
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.graph_objs as go
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets = external_stylesheets)
graph = dcc.Graph(figure = {
'data' : [
go.Scatter(x = [1,4], y = [2,3], mode = 'lines+markers', opacity = 0.7,
marker={'color':["red","green"], "size":15})
]
})
app.layout = html.Div([graph])
if __name__ == '__main__':
app.run_server(debug = False)
我正在尝试使用 plotly 和 dash 为 webapp 创建一个简单的折线图。我想要一条连接两点的线。我想要一个点是红色的,另一个是绿色的。这是我目前拥有的:
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.graph_objs as go
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets = external_stylesheets)
graph = dcc.Graph(figure = {
'data' : [
go.Scatter(x = [1,4], y = [2,3], mode = 'lines+markers', opacity = 0.7, marker = {
'size' : 15,
'line' : {'width' : 0.5, 'color' : 'black'}
})
]
})
app.layout = html.Div([graph])
if __name__ == '__main__':
app.run_server(debug = False)
我运行在 Jupyter notebook 中使用所有最新的软件包来编写此代码。 如果我 运行 这段代码,我会得到我想要的线图,但两个点都是蓝色的。我希望 (1, 2) 对应的点为红色,(4, 3) 对应的点为绿色。我该怎么做呢? 提前致谢!
我认为这个问题的公认解决方案是在图形数据中包含 3 个不同的 go.scatter()
对象。一个用于线条,一个用于每个标记。您的应用最终会看起来像这样:
import dash
import dash_core_components as dcc
import dash_html_components as html
import plotly.graph_objs as go
external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets = external_stylesheets)
graph = dcc.Graph(figure = {
'data' : [
go.Scatter(x = [1,4], y = [2,3], mode = 'lines+markers', opacity = 0.7,
marker={'color':["red","green"], "size":15})
]
})
app.layout = html.Div([graph])
if __name__ == '__main__':
app.run_server(debug = False)