2
0

iPhone ショートカットで勤怠管理

Last updated at Posted at 2024-03-30

どうも
最近ニート卒業してIT派遣として働き始めたんですが

勤怠管理をEXCELで!!?

びっくらこいた、毎月の勤怠をExcelで提出するといった作業が必要で、自分で出勤・退勤時間を記録する必要があったのでどうせならスマホで打刻できるようにしようと考えました。
時給制でもあるので日額計算もできるようにしています。

できたもの

ショートカットをロック画面に追加して実行できるようにしています。
example.gif
(ちょっと出勤時間をいじってます)
スクリーンショット 2024-03-30 22.09.48.png

構成

とりあえずiPhoneのショートカットで作ろうと考えました。
ただ自分のiPhoneのスペックが低いのかアクションが多くなってくると重くなってくるし、画面が小さいので条件分岐をつけたりすると頭がバグりそうになってくるのでところどころ処理を分割することにしました。
(それでも辛かったので結局macで作成しました)

構成としては以下です。

IMG_0569.jpg

アプリ

  • 出退勤
    • ここが打刻処理の入り口、ホームに追加したりして起動するショートカット
  • 勤怠表取得
    • 当月の打刻をまとめてcsvとして出力するショートカット

関数群

  • 休憩時間
    • 休憩時間を設定するショートカットで、基本読み取り
  • 分給
    • 正確な日額の計算をするために時給を設定して、それを分給に変換して返すショートカット
  • 日額計算
    • 出勤と退勤の時間差を受けとって休憩時間を反映し分給で計算
    • 通知で表示する用の実働時間と日額をテキストで返す
  • 各月prefix
    • 実行時の月を二桁で返す(2月なら02を返す)
    • 勤務表データを作る際に検索用でカレンダーのタイトルにつけるため

実行内容

出退勤

  1. [各月prefix] を実行して取得(以下変数 ${prefix} )
  2. 出勤時にタイトルが ${prefix}出勤 (例. 02出勤) で開始と終了日時を実行時で追加する
  3. 再度実行時に予定があればタイトルを ${prefix}出勤/退勤 にして、終了日時を実行日時で変更
    1. 開始と終了の時間差を取得して [日額計算] に渡して実行
    2. 実働時間と日額のテキストが返ってくるのでそれを通知として表示
  4. 実行時に ${prefix}出勤/退勤 のタイトルの予定があれば 「すでに登録されています」を通知

スクリーンショット 2024-03-30 21.08.03.png
スクリーンショット 2024-03-30 21.08.30.png
スクリーンショット 2024-03-30 21.08.42.png

勤務表取得

  1. [各月prefix] を実行して取得(以下変数 ${prefix} )
  2. タイトルが ${prefix}出勤/退勤の予定を過去一年内から取得
  3. 取得した予定を古い順に並べてcsvに保存

スクリーンショット 2024-03-30 21.18.48.png

休憩時間

  1. 時間を設定してそれを分に変換して返す

スクリーンショット 2024-03-30 21.24.17.png

分給

  1. 時給を入れてそれを分給に変換して返す

スクリーンショット 2024-03-30 21.26.05.png

日額計算

  1. 出勤と退勤の差を受け取る
  2. [休憩時間] を実行して取得
  3. 出勤と退勤の差から休憩を引いて実働時間を計算
  4. [分給] を実行して取得
  5. 上で計算した実働時間とかけて日額の計算
  6. 返す値をテキストでまとめる

スクリーンショット 2024-03-30 21.30.57.png

各月prefix

  1. 実行時の日付をフォーマットして二桁の月 (02, 11, とか)を返す
    スクリーンショット 2024-03-30 21.32.41.png

ちょっとしたこと

  • 基本打刻時の秒数は無視だと思うので出勤時と退勤時の時間のフォーマットから ss を削除してます
  • csv保存時は作成した時強制的に .txt ファイルになってしまったので作成後に .csv に変更しています

あとがき

結構関数ぽく作れるので面白かったです
帰りの電車で作ってたら熱中し過ぎて降りる駅を過ぎてしまい歩く羽目になりました()

2
0
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
2
0