20
16

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.

Emacs&Org-modeで始めるタスク管理と作業時間計測

Posted at

はじめに

私は,大学時代からEmacs & Org-modeでタスクを管理してきました.一方,作業時間は管理していませんでした.
社会人になってからもタスクのみを管理していましたが,以下の理由から作業時間も管理する必要性を感じていました.

  • 理由1: お客さまとの契約毎,社内作業分類毎に作業時間を計上したい
  • 理由2: 作業時間実績を把握し,作業時間見積精度を向上したい

そんな折,自身のタスク管理方法を紹介する機会が生まれ,(新型コロナ感染防止を理由に延期されておりますが.)
この機会に必要性を感じていた作業時間管理を実現し,作業時間管理方法も一緒に説明しよう!
ということで,今年度からEmacs & Org-modeでタスク管理に加え,作業時間管理を始めました.
本記事を執筆した2020/04/22現在時点で,かれこれ1か月ほど運用しています.

本記事は,私のEmacs & Org-modeでのタスク管理,および,作業時間計測方法を紹介します.
また,上記を実現するElisp設定を紹介します.

こんな方に読んでほしい

  • タスクを忘れて人に迷惑をかけた経験がある.タスクを忘れないよう,管理したい.
  • 作業時間の記録を付けているが,記憶ベースで記録している.実態に即して記録したい.
  • 社外に情報が出るため,Webシステムでのタスク管理や作業時間計測はできない.ローカルファイルで記録したい.

前提知識

  • Emacsの環境構築方法
  • elispの読み方
  • Emacsによくあるショートカットキーの読み方(C-, SPC...)

運用

考え方

タスク状態

  • 未完了状態群
    • TODO: 登録されたばかりのタスク.
    • NEXT: 現在進行中,または,仕掛中のタスク.直近着手すべき.
    • WAITING: 他人の作業待ちのタスク.待ち内容を記載する.
    • HOLD: 自分が諸事情で延期中のタスク.延期理由を記載する.
  • 完了状態群
    • DONE: 完了したタスク.
    • CANCELLED: 実施不要と判断したタスク.判断理由を記載する.
    • PHONE: 計時用タスク.電話したことを示す.
    • MEETING: 計時用タスク.会議・ちょっとした会話を示す.

ファイル・タグ構成

Org-modeには,ファイル内の全項目にタグをつける設定(#+FILETAGS:)があります.
そこで,タグ毎にファイルを分割し,タスクを管理しています.

ファイル名 タグ 概要
refile.org REFILE Org-captureの記録項目を一時格納する.
OwnCompany.org OwnCompany,@office 社内タスクを格納する.
CustomerName-SystemName.org CustomerName,SystemName,@office CustomerNameというお客さまのSystemNameというシステム関連のタスクを格納する.
clock-table.org ETC 作業時間集計用ファイル.

作業流れ

概要

業務の流れになぞらえて,Emacs & Org-modeによるタスク管理と作業時間計測流れを説明します.
以降の説明ではスクリーンショットとアニメーションgifを用いています.
これらは私用環境で撮影しており,ファイル・タグ構成と構成が異なる点に注意してください.

週次レビュー(週初め営業日の場合)

作業開始

F12 SPC wを押下し,週次アジェンダを呼び出します.
wrrklyAgemda.gif
週次アジェンダ上で,Weekly Task Reviewにカーソルを合わせ,Iを押下すると,Org-mode上の作業時間計測が始まります.
現在の作業時間計測対象タスク,および,その作業時間累計は図中赤丸で確認できます.
image.png
ちなみに,作業時間計測停止時は,C-c C-x C-oを押下します.
作業時間計測停止時,タスクにカーソルを合わせる必要はありません.

週次のタスク実施日設定・見直し

週次アジェンダには,現在週に実施予定日,または,締切日があるタスクが表示されます.
週次アジェンダの各タスクを見て,実施予定日,または,締切日を再設定していきます.
タスクにカーソルを合わせ,C-c C-sで予定日,C-c C-dで〆切日を入力できます.
以下のように,上記ショートカットを入力するとカレンダが表示されます.
image.png
この状態で,Shift-カーソルキー入力により,カレンダから日付を選択します.Enterで確定です.

私は,タスクの実施日予定,または,締切日を明確にできない場合,
翌週月曜に実施予定日を設定し,翌週の週次レビューで当該タスクを棚卸しします.
これにより,永続的なタスク放置を防止しています.

週次の未分類タスク分類

以下のように,リファイル待ちヘッダには未分類タスク一覧が表示されます.
image.png
まず,分類前にタスクにカーソルを合わせTABキーで実施予定日,または,締切日が設定されているかを確認します.
確認時に未設定の場合,実施予定日,または,締切日を設定します.
これは,実施予定日と締切日を未設定のまま分類されたタスクは,
日次アジェンダ,および,週次アジェンダで表示されず,棚卸しされなくなってしまうためです.

以下では,TABでの確認時,未設定であったため,実施予定日を04/20に設定しています.
ConfirmSchedule.gif

実施予定日,または,締切日を設定後,タスクをお客さまとの契約,または,社内作業分類に分類します.
タスク分類は,タスクにカーソルを合わせてC-c C-wで可能です.
以下のアニメーションgifでは,VRChatのワールドをUnity2018対応するタスクをVRChatWorldに分類しています.
Refile.gif
なお,私は,インクリメンタル検索インタフェースにHelmを使っています.
Helmでは,上記アニメーションgifのようにファイル名の一部,あるいは,分類のキーワードから分類先を簡単に検索できます.

作業終了

週次アジェンダ上で,Weekly Task Reviewにカーソルを合わせ,
tを押下するとタスク状態一覧とショートカットキーが表示されます.
作業終了時は,dを押下します.
image.png

dの押下時,Org-modeは週次レビューが作業時間計測対象であること,および,
作業時間計測対象が完了状態になったことを検知し,週次レビューの作業時間計測を停止します.

日次レビュー

コミュニケーションツールからのタスク収集

メーラやチャットツールからタスクをOrg-captureで収集します.
Org-captureは,事前指定したテンプレートで情報を記録する機能です.
私は,Org-captureをC-c cに設定しています.C-c cを押下すると,以下の画面が表示されます.
image.png
この画面では,各テンプレートのショートカットキーと,名前が表示されます.
例えば,tを押下すると,通常のタスク記録テンプレートが呼び出せます.
同様に,rを押下すると,メール返信テンプレートが呼び出せます.
tを押下すると,以下の画面が表示されます.
TODOの右側に自動でカーソルが移動するため,タスク名だけを入力し,C-c C-cで保存します.
image.png

日次のタスク実施日設定・見直し

F12 SPCを押下して日次アジェンダを表示し,タスクの実施予定日,締切日を再確認します.
対象スコープの相違を除き,週次のタスク実施日設定・見直しと同じ運用です.

日次の未分類タスク分類

週次の未分類タスク分類同様,リファイル待ちに表示されるタスクを分類します.
コミュニケーションツールからのタスク収集で登録したタスクもリファイル待ちに表示されます.
私は,このタイミングで実施予定日,または,締切日を計画します.

1日の作業実施順序計画

日次の未分類タスク分類までの作業により,今日やるべきタスクがOrg-modeファイル群に書き込まれた状態です.
この状態で,日次アジェンダでrを押下し,日時アジェンダを更新します.
すると,今日の日付の下に今日やるべきタスクが一覧されます.
ここで,以下のアニメーションgifように,タスクにカーソルを合わせ,
Alt-Upまたは,Alt-Downでタスクを動かし,表示順序を作業実施順序と合致するよう整列します.
Move.gif

このように表示順序を作業実施順序と合致するよう整列する理由は,
精神的コストが大きい次作業の選択を日中にしないためです.
日中は,整列したタスクを上から順に取り掛かれば,次作業の選択が不要となります.

前営業日の作業時間確認

弊社では,1日単位でお客さまとの契約毎の工数を記録します.
そこで,私は契約毎の工数をclock table機能で自動計上しています.
任意のOrg-modeファイルに以下を記載し,#+BEGIN:の行でC-c C-cを押下すると,
agenda対象ファイルを眺め,昨日の作業時間を集計します.

#+BEGIN: clocktable :maxlevel 1 :block yesterday :scope agenda :fileskip0 t
#+END

集計後イメージは,以下の通りです.
image.png

設定により,様々な作業時間集計が可能です.
詳しくは,公式ドキュメントを参照ください.

作業実施時

作業の開始

作業開始でも述べたとおり,
作業開始時はアジェンダのタスクにカーソルを合わせ,Iで作業時間を計測します.
また,アジェンダのタスクにカーソルを合わせt nと押下してタスクをNEXT状態にします.
これにより,タスク中断時,仕掛中であるとわかるようにします.

作業のメモ

Org-modeでは,タスク内にメモができます.
アジェンダのタスクにカーソルを合わせTabを押下するとタスクが展開されます.自由にメモしましょう.
Tab.gif

作業の中断

作業時間の計測を,C-c C-x C-oで停止します.
さらに,タスクを本日中に再開できない場合,tを押下してタスクをWAITING,または,HOLDにしておきます.
この時,以下のような画面が表示されるので,中断理由を記録しておきます.
image.png

また,中断理由記録後は,C-c C-sで中断理由が解消されたか棚卸予定日を設定し,
C-c C-dでタスク中断の許容日付を設定します.

この作業により,棚卸予定日になると日次アジェンダにタスクが表示され,確実な棚卸しが可能です.
また,タスクをTABで確認すると,タスク中断の許容日付が明確になっており,
「これって今お客さまをフォローしなきゃいけないんだっけ?」と悩む必要もありません.

ちょっとした会議,同僚との会話,お客さまからの電話

ちょっとした会議,同僚から話かけられる,お客さまからの電話で作業が中断されることがあります.
皆さんもそんな経験は,1度や2度ではないですよね.
そんな時は,現在のタスクの計時を終了せず(重要)C-c cを押下し,Org-captureを起動します.
image.png
ここで,mpを押下すると,MEETINGPHONEのタスクが生成されます.
この時,自動的に生成タスクの作業時間が計測開始されます.
ちょっとした会議,同僚との会話,お客さまからの電話が終わったら,C-c C-cでタスクを記録します.
すると,生成タスクの作業時間が計測終了したうえで,中断したタスクの計時を再開します.その様子が,以下です.
clock.gif

これで,突然の割込み作業時間計測もばっちりですよ.(まだ慣れてなくてたまにOrg-captureを忘れますが...)

Elisp

概要

運用の実現に必要なElisp設定を抜粋し,記載します.

Org-modeディレクトリ,ファイル変数の定義

10-org.el
;; Dropbox導入環境では,Dropboxを優先的に山椒するよう設定.
(setq org-directory "~/Documents/org/")
(when (file-exists-p "~/Dropbox/org/")
  (setq org-directory "~/Dropbox/org/"))
(setq org-default-notes-file (concat org-directory "refile.org"))

TODO状態定義設定

10-org.el
;; "|"から右に記載した状態は,完了状態として扱われる.
;; 状態名後の"()"内に状態遷移についての設定を記載する.
;; 1文字目: C-c C-t 押下時に当該状態を選択するためのショートカット.
;; "@": 当該状態に遷移した時,アノテーションの記載を強制する.
;; /!: 当該状態に遷移した時,当該状態への遷移時刻を自動記録する.
(setq org-todo-keywords
      (quote ((sequence "TODO(t)" "NEXT(n)" "|" "DONE(d)")
              (sequence "WAITING(w@/!)" "HOLD(h@/!)" "|" "CANCELLED(c@/!)" "PHONE" "MEETING"))))

TODO状態遷移時のタグ付け指定

10-org.el
;; t付きのtupleは,当該状態に遷移した時,そのタグを付与することを示す。
;; ここで付与したタグを活用し,agendaを表示する.
(setq org-todo-state-tags-triggers
      (quote (("CANCELLED" ("CANCELLED" . t))
              ("WAITING" ("WAITING" . t))
              ("HOLD" ("WAITING") ("HOLD" . t))
              (done ("WAITING") ("HOLD"))
              ("TODO" ("WAITING") ("CANCELLED") ("HOLD"))
              ("NEXT" ("WAITING") ("CANCELLED") ("HOLD"))
              ("DONE" ("WAITING") ("CANCELLED") ("HOLD")))))

agenda設定

10-org.el
;; デフォルトで1日のビューとする。
(setq org-agenda-span 'day)

;; agenda 表示の対象ファイル
;; 計時の集計対象にもなる.
(setq org-agenda-files (list org-directory))

;; Custom agenda command definitions
;; tags-todoは、タグ/TODO状態で検索条件を指定。!はDONEでないタスクに検索対象を限定する。
(setq org-agenda-custom-commands
      (quote (("N" "Notes: メモ一覧" tags "NOTE"
               ((org-agenda-overriding-header "Notes")
                (org-tags-match-list-sublevels t)))
              ("h" "Habits: 習慣タスク一覧" tags-todo "STYLE=\"habit\""
               ((org-agenda-overriding-header "Habits")
                (org-agenda-sorting-strategy
                 '(todo-state-down effort-up category-keep))))
              (" " "Agenda: 予定表"
               ((agenda "" nil)
                (tags "REFILE"
                      ((org-agenda-overriding-header "リファイル待ち")
                       (org-tags-match-list-sublevels nil)))
                (tags-todo "-CANCELLED/!NEXT"
                           ((org-agenda-overriding-header "NEXTタスク")
                            (org-tags-match-list-sublevels t)
                            (org-agenda-sorting-strategy
                             '(todo-state-down effort-up category-keep))))
                (tags-todo "-HOLD-WAITING-CANCELLED/!-NEXT"
                           ((org-agenda-overriding-header "処理待ち(NEXT候補)")
                            (org-tags-match-list-sublevels 'indented)
                            (org-agenda-sorting-strategy
                             '(category-keep))))
                (tags-todo "-CANCELLED+WAITING|HOLD/!"
                           ((org-agenda-overriding-header "他者作業待ち・延期中")
                            (org-tags-match-list-sublevels nil)))
               nil)))))

キーバインド設定

00-keybind.el
;; 頻繁に実行するagendaは1キーで起動するように定義します.
(global-set-key (kbd "<f12>") 'org-agenda)

おわりに

本記事では,Emacs & Org-modeでのタスク管理方法,および,作業時間計測方法を紹介しました.
また,上記を実現するElisp設定を紹介しました.
これを機に,EmacsやOrg-modeでのタスク管理,および,作業時間計測に興味を持ってもらえたら幸いです.
皆さんも,EmacsやOrg-modeに限らず,思い思いの方法で確実なタスク管理と作業時間計測を実現しましょう!
そして,その情報を共有してお互いのタスク管理方法と作業時間計測方法をよりよくしましょう!

参考文献

20
16
0

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
20
16

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?