81
93

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

Excelでガントチャート自動作成ツールを作ってみた

Last updated at Posted at 2019-12-02

RPA Advent Calendar 2019 2日目ですね。滑り込みですみません。
2日目にしてちょっと趣向を変えてみます。

##今回作ったもの
WBSからガントチャートを自動作成するツールをExcelで自作してみました。

ポイントは3点。

  1. シンプルであること
  2. プロジェクトの開始日/終了日、タスク、担当者、工数さえ決めれば、勝手にガントチャートを作ってくれること。期限内に終わらない場合はアラートで知らせてくれること。
  3. 割込タスクが入ったり、タスクの工数が膨らんだら、以降のタスクを自動的にスライドしてくれること

#####デモ

#####WBS作成前 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/186221/31ef3d33-c60a-971c-ca46-2d482d71118b.png) #####WBS作成後 ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/186221/2030e690-56d5-fb21-1b90-b255e66468bd.png) #####Config ![image.png](https://qiita-image-store.s3.ap-northeast-1.amazonaws.com/0/186221/2024620e-9782-cd4b-d7e1-d08058912d45.png)

##今回実装する機能

機能 実装すること
ガントチャート作成 - グループ、担当者、予定工数を考慮したGC作成
- 開始予定日を太字⇒必ずその日からタスク開始
- プロジェクト期限内に終わらない場合はアラートを出す
- 開始日を太字⇒現在の進捗を青枠で表示
- 開始日&完了日を入力⇒実績を赤枠で表示
- 土日祝日、各担当者の非稼働日を考慮
行追加 選択しているセルの行+1行目に、前タスクをコピーした内容の行を追加
行削除 選択しているセルの行を削除
エクスポート WBS+ガントチャートを別ファイルに出力
ガントチャート初期化 作成されたガントチャートを初期化

##機能解説
###ガントチャート作成
####初期設定
#####プロジェクト開始日/終了日を決める
まず、プロジェクトの開始日/終了日を決めます。表示上はM/dですが、値はyyyy/M/dです。
image.png

終了日は、全タスク×工数がプロジェクトの期限内に収まるか判定するために必要です。
収まらなかった場合、WBS作成時に以下のようなアラートが出て処理が止まります。
image.png

#####Configを設定する
image.png

設定できる内容は、

  • 祝日、(プロジェクト共通の)非稼働日
  • 各担当者の設定
    • ガントチャートの色
    • 非稼働曜日
    • 非稼働日

です。
(プロジェクト共通の)非稼働日には、夏休みや年末年始の休暇などの日付を入れておくと良いでしょう。
各担当者の非稼働曜日は、個人的に欲しかった項目です(笑)
なぜなら、週1,2常駐の案件を掛け持ちしたとき、曜日でタスクを区切ることが多いからです。月、水はAプロジェクト、火、木はBプロジェクト…といった管理を自動でやってくれるとかなり助かります。
各担当者の非稼働日は、例えば有給休暇などの予定が入った場合に随時追加していけば、その日以降のタスクスケジュールも自動計算してくれます。

非稼働日を考慮してくれることで、メンバー全員が休みを取ることに怯えることなく(笑)健康的にプロジェクトを進めることができます。素晴らしい☆

####タスクをグループ化する
今回のWBSツールでは、複数のタスクをグループ化して管理します。グループ番号はそのまま消化の順番になります。
グループに属する各タスクはウォーターフォールでスケジュールが引かれることになります。

image.png
例えば上図の場合、2020/1/6までの斎藤さんのタスクが完了しないと、次タスクの「プロセス/オブジェクトレビュー」が行えないことになります。

タスクによりますが、2020/1/10から始まる鈴木さんのタスクが、斎藤さんがタスク消化している間に並行して進められる内容であれば、前倒して実施することももちろんできるでしょう。
その場合、以下のように一度自動的にWBSを作成した後に、2020/1/10からの鈴木さんのタスク開始予定日を「2020/1/6」からに変更してみましょう。

鈴木さんのタスク開始予定日を「2020/1/6」に変更し、太字にします(Ctrl+B)
image.png

その後、WBS作成ボタンを押します。
細かいけど、本当はGC(ガントチャート)作成の方が良かったかも…
image.png

すると、鈴木さんのタスク開始予定日は「2020/1/6」からになります。
このようにタスク開始予定日を太字にすると、問答無用でその日からタスクが始まります。
その日が土日祝日、プロジェクト共通 or 担当者ごとの非稼働日も一切無視されますので、利用するときは注意しましょう。気づかないうちに休出前提のスケジュールになってたなんてことがないように…
image.png

グループ番号について補足します。
例えばグループ番号「1」「2」「3」があったとします。
この場合、グループ番号1の全タスク消化後、グループ番号2に着手する流れとなります。
image.png

####進捗・実績を表示する
予定だけでなく、実績も表示したいですよね。やっちゃいましょう☆
image.png

表現を2パターン用意しています。

  • 進捗中
  • タスク消化実績

進捗中とは、まだそのタスクを消化中で未完の場合を指します。
その場合、「開始日」列の日付欄に日付を入力し、太字にします。
image.png

すると、ガントチャートのバーに青枠が追加されます。これで進捗中のタスクであることが表現されました。
image.png

タスク消化実績とは、タスクが完了していて、結果的にいつからいつまでタスク消化に時間を充てていたかを表す実績のことです。
その実績を表現するには、「開始日」列に日付を入力するだけです。
image.png

すると、ガントチャートのバーに赤枠が追加されます。これで実績が表現されました。
image.png

####プロジェクト共通の非稼働日を設定する
Configシートに非稼働日を設定することができます。
ここで設定する祝日、非稼働日はプロジェクト共通なので、メンバー全員に適用されます。
image.png

#####土日祝日
土日はデフォルトで非稼働日として設定されます。明示的に設定する必要はありません。
土日も稼働したい場合は、前述した開始予定日を太字にしてムリヤリ稼働させましょう。
祝日はyyyy/M/d形式で明示的に設定する必要があり、ちょっと面倒なのですが、以下サイトなどからコピペで良いでしょう。
Excel最新版!2019年~ 祝日一覧(2019年~2022年まで)

#####担当者別ガントチャートの色、非稼働曜日、日付
image.png
ここで、プロジェクトメンバーと各メンバーの色、非稼働曜日/日を設定することができます。
曜日は月~金をカンマ区切りで設定する形となります。以下のように曜日順は問いません。
image.png

各メンバーの非稼働日はいくつ設定してもOKです。

###エクスポート
例えば、お客さんにWBSをシェアする必要がある場合、前述した機能がそのまま使えてしまうと、スケジュールが改変される恐れがあります。
なので、ツールはこちらで持っておき、お客さんにはxlsxファイルのWBSを提供したいところです。

エクスポートボタンを押すと、名前を付けて保存ダイアログが表示されます。
ファイル名は「WBS_(今日の日付)」がデフォルトでは入っています。後は保存するだけです。
image.png

この機能も、プロジェクト期間やタスク数などにより多少時間がかかる場合があります。
以下ダイアログが表示されたらエクスポート完了です。
image.png

ヘッダーの色など多少変化はありますが、複製できています。よしよし☆
ボタン群も削除されています。
image.png

###ガントチャート初期化
作成したガントチャートを初期化します。
各タスクの「完了日」列より左の項目は消されませんのでご安心を。

使い方は、GC初期化ボタンを押すだけです。
※GCはガントチャート(Gantt chart)の略です。
image.png

#####初期化前
image.png
#####初期化後
image.png

###その他
#####今日の日付列は薄い赤色で表示される
分かるに越したことはないでしょう。
image.png

#####非稼働日はグレーで表示される
特に、各担当者の非稼働日がタスク別でもちゃんと表示される点は、我ながらポイント高いと思っています(笑)
下図の場合、鈴木さんは月~水、佐藤さんは水曜日が非稼働日だということが分かります。
image.png

##2021/02/01 v1.1 UPしました

修正点

  • スケジュールの開始日以前に本ツールでWBSを作ろうとすると処理が途中で止まってしまうバグを修正
    image.png

  • 直近の自分のタスクの終了日を起点に次のタスク開始日を決められる
    ちょっと何言ってるか分かんないと思いますが(笑)図のH列に何らかのテキストを入力すると、誰かのタスクが終わらないと着手できないタスクではなく、直近の自分のタスクが終わればすぐに着手できるタスクとしてみなすことができる機能を追加しました。
    image.png

eng1のタスクに注目してください。
一つ上のタスク「単体テスト再実施」より日付が過去になっています。これはeng1の直近のタスク終了日3/10を起点にタスクの開始日を設定しているからです。
3/12の左のセルに「1」が入っていることにより、このようなスケジュールの設定が可能になっています。
image.png

3/12の左のセルに何も入力しなければ、タスク開始日は3/19になります。
image.png

##ツール置いてます
本記事で紹介したWBSツールです。

easyWBS_v1.2

81
93
2

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
81
93

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?