Plotly 甘特圖
-
在 Python 中使用
plotly.express
的timeline()
函式建立甘特圖 -
在 Python 中使用
plotly.figure_factory
的create_gantt()
函式建立甘特圖
本教程將討論在 Python 中使用 Plotly 的 timeline()
和 create_gantt()
函式建立甘特圖。
在 Python 中使用 plotly.express
的 timeline()
函式建立甘特圖
甘特圖用於顯示專案進度。我們可以使用 plotly.express
的 timeline()
函式來建立甘特圖。
我們必須建立一個資料框,該資料框應包含三個變數任務、開始資料和結束日期。
任務應該是一個包含作業名稱的字串。開始和結束日期應該是格式年-月-日的字串。
例如,讓我們建立一個包含三個作業的資料框,使用 timeline()
函式建立其甘特圖,並使用 color
引數為每個條形圖賦予不同的顏色。請參閱下面的程式碼。
import plotly.express as px
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = px.timeline(df, x_start="Start", x_end="Finish", y="Task", color="Task")
fig.show()
輸出:
我們可以使用 color_discrete_sequence
引數更改預設顏色序列。我們可以將顏色序列設定為 Plotly 支援的顏色序列,如 Dark24
或 Light24
。
例如,讓我們改變上面直方圖的顏色和圖案順序。請參閱下面的程式碼。
import plotly.express as px
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = px.timeline(
df,
x_start="Start",
x_end="Finish",
y="Task",
color="Task",
color_discrete_sequence=px.colors.qualitative.Light24,
)
fig.show()
輸出:
除了使用顏色序列,我們還可以使用 color_discrete_map
引數為每個條形賦予任何顏色。此引數用於覆蓋預設顏色。
如果我們只更改幾個條形顏色,其餘的將從顏色序列中分配。
例如,讓我們將前兩個條形顏色更改為黃色和黑色。請參閱下面的程式碼。
import plotly.express as px
values = [[3, 4, 5], [2, 2, 2]]
labels = ["Day1", "Day2", "Day3"]
fig = px.histogram(
x=labels,
y=values,
width=500,
height=400,
color=labels,
pattern_shape=labels,
color_discrete_sequence=px.colors.qualitative.Light24,
pattern_shape_sequence=["-", ".", "x"],
color_discrete_map={"Day1": "yellow", "Day2": "black"},
)
fig.show()
輸出:
我們還可以使用 title()
引數更改圖表的標題並將其值設定為字串。我們可以使用 width
和 height
引數來設定圖表的寬度和高度(以畫素為單位)。
我們可以使用 hover_name
引數設定懸停標題,並將其值設定為資料框列或字串列表。我們還可以使用 text
引數在每個欄內新增文字,並將其值設定為資料框列或字串列表。
我們可以使用 opacity
引數設定條形的不透明度,並將其值設定為 0 到 1。要將甘特圖轉換為在每個子圖中包含單個條形的一組子圖,我們可以將 facet_row
用於行和 facet_col
用於列並將其值設定為整數或字串列表將用於設定子圖的名稱。
我們可以使用 facet_row_spacing
和 facet_col_spacing
引數更改每個子圖之間的間距,並將其值設定為從 0 到 1 的浮點數。
例如,讓我們更改上面提到的屬性。請參閱下面的程式碼。
import plotly.express as px
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = px.timeline(
df,
x_start="Start",
x_end="Finish",
y="Task",
color="Task",
title="Gantt Chart",
hover_name="Task",
text="Task",
opacity=0.8,
facet_row="Task",
)
fig.show()
輸出:
在 Python 中使用 plotly.figure_factory
的 create_gantt()
函式建立甘特圖
我們可以使用 plotly.figure_factory
的 create_gantt()
函式來建立甘特圖。我們必須建立一個資料框,該資料框應包含三個變數任務、開始資料和結束日期。
任務應該是一個包含作業名稱的字串。開始和結束日期應該是格式年-月-日的字串。
例如,讓我們建立一個包含三個作業的資料框並建立它的甘特圖。請參閱下面的程式碼。
import plotly.figure_factory as pff
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = pff.create_gantt(df)
fig.show()
輸出:
我們可以使用 index_col
和 colors
引數更改每個條的顏色。我們必須定義要在顏色設定中使用的列,並將其傳遞到 index_col
引數中,就像我們可以將其設定為任務一樣,使用任務名稱為每個條形圖賦予顏色。
我們可以使用 colors
引數中的任務名稱和 RGB 值來設定顏色。例如,讓我們設定上圖中每個條的顏色。
請參閱下面的程式碼。
import plotly.figure_factory as pff
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = pff.create_gantt(
df,
index_col="Task",
colors={"Job A": "rgb(255,0,0)", "Job B": "rgb(0,255,0)", "Job C": "rgb(0,0,255)"},
)
fig.show()
輸出:
我們可以使用 show_colorbar
引數顯示顏色條並將其設定為 true。我們可以使用 group_task
引數來設定每個條的位置。
我們可以使用 showgrid_x
和 showgrid_y
引數來顯示或隱藏 x 和 y 軸網格。我們可以使用 bar_width
引數設定條的寬度並將其設定為浮點值。
我們還可以使用 title()
引數更改圖表的標題並將其值設定為字串。我們可以使用 width
和 height
引數來設定圖表的寬度和高度(以畫素為單位)。
我們還可以使用 show_hover_fill
引數啟用或禁用填充區域的懸停文字,並將其值設定為布林值。
例如,讓我們更改上面提到的屬性。請參閱下面的程式碼。
import plotly.figure_factory as pff
df = [
dict(Task="Job A", Start="2022-01-01", Finish="2022-02-28"),
dict(Task="Job B", Start="2022-03-05", Finish="2022-04-15"),
dict(Task="Job C", Start="2022-02-20", Finish="2022-05-30"),
]
fig = pff.create_gantt(
df,
index_col="Task",
colors={"Job A": "rgb(255,0,0)", "Job B": "rgb(0,255,0)", "Job C": "rgb(0,0,255)"},
show_colorbar=True,
group_tasks=True,
showgrid_x=True,
bar_width=0.5,
)
fig.show()
輸出: