Plotly 甘特圖

Plotly 甘特圖

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

本教程將討論在 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 更改甘特圖的屬性

Author: 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

  • Plotly 3D 散點圖
  • Plotly 桑基圖
  • Plotly 條形圖
  • Plotly 樹狀圖
  • Plotly 熱圖