Plotly 甘特圖

Ammar Ali 2023年1月30日
  1. 在 Python 中使用 plotly.expresstimeline() 函式建立甘特圖
  2. 在 Python 中使用 plotly.figure_factorycreate_gantt() 函式建立甘特圖
Plotly 甘特圖

本教程將討論在 Python 中使用 Plotly 的 timeline()create_gantt() 函式建立甘特圖。

在 Python 中使用 plotly.expresstimeline() 函式建立甘特圖

甘特圖用於顯示專案進度。我們可以使用 plotly.expresstimeline() 函式來建立甘特圖。

我們必須建立一個資料框,該資料框應包含三個變數任務、開始資料和結束日期。

任務應該是一個包含作業名稱的字串。開始和結束日期應該是格式年-月-日的字串。

例如,讓我們建立一個包含三個作業的資料框,使用 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 支援的顏色序列,如 Dark24Light24

例如,讓我們改變上面直方圖的顏色和圖案順序。請參閱下面的程式碼。

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() 引數更改圖表的標題並將其值設定為字串。我們可以使用 widthheight 引數來設定圖表的寬度和高度(以畫素為單位)。

我們可以使用 hover_name 引數設定懸停標題,並將其值設定為資料框列或字串列表。我們還可以使用 text 引數在每個欄內新增文字,並將其值設定為資料框列或字串列表。

我們可以使用 opacity 引數設定條形的不透明度,並將其值設定為 0 到 1。要將甘特圖轉換為在每個子圖中包含單個條形的一組子圖,我們可以將 facet_row 用於行和 facet_col 用於列並將其值設定為整數或字串列表將用於設定子圖的名稱。

我們可以使用 facet_row_spacingfacet_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_factorycreate_gantt() 函式建立甘特圖

我們可以使用 plotly.figure_factorycreate_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()

輸出:

使用 create_gantt 的簡單甘特圖

我們可以使用 index_colcolors 引數更改每個條的顏色。我們必須定義要在顏色設定中使用的列,並將其傳遞到 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()

輸出:

使用 create_gantt 更改甘特圖的顏色

我們可以使用 show_colorbar 引數顯示顏色條並將其設定為 true。我們可以使用 group_task 引數來設定每個條的位置。

我們可以使用 showgrid_xshowgrid_y 引數來顯示或隱藏 x 和 y 軸網格。我們可以使用 bar_width 引數設定條的寬度並將其設定為浮點值。

我們還可以使用 title() 引數更改圖表的標題並將其值設定為字串。我們可以使用 widthheight 引數來設定圖表的寬度和高度(以畫素為單位)。

我們還可以使用 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()

輸出:

使用 create_gantt 更改甘特圖的屬性

作者: Ammar Ali
Ammar Ali avatar Ammar Ali avatar

Hello! I am Ammar Ali, a programmer here to learn from experience, people, and docs, and create interesting and useful programming content. I mostly create content about Python, Matlab, and Microcontrollers like Arduino and PIC.

LinkedIn Facebook

相關文章 - Plotly Plot