Rumah >pembangunan bahagian belakang >Tutorial Python >Panduan Jurutera Lazy untuk Mengautomasikan Timesheets: Bahagian 1

Panduan Jurutera Lazy untuk Mengautomasikan Timesheets: Bahagian 1

Patricia Arquette
Patricia Arquetteasal
2025-01-29 08:14:11953semak imbas

The Lazy Engineer’s Guide to Automating Timesheets: Part 1

Timesheets: The Bane of Every Cheedner's Engineer. Bukankah anda lebih suka bergelut bug kompleks pada pukul 3 pagi daripada mendokumentasikan hari kerja anda dengan teliti? Malangnya, pekerjaan freelancing atau sepenuh masa sering memerlukan tugas yang membosankan ini.

Tahun ini, saya mencapai had saya. Selepas tahun projek yang sibuk-beberapa dibatalkan, beberapa yang direka bentuk semula, yang lain ditangguhkan selama-lamanya-saya menghadapi tarikh akhir timesheet akhir tahun yang menjulang. Prospek untuk mencipta semula kerja sepanjang tahun saya adalah menakutkan. Penyelesaian saya? Automatikkannya.

Ini adalah perjalanan saya dari timesheet dread ke pengembaraan pengekodan. Bersedia untuk pendekatan yang efisien dan cekap.

Masalah: Timesheets adalah mimpi ngeri

mari kita tetapkan panggung:

    Cabaran:
  • Rekod setiap jam yang dibelanjakan untuk setiap tugas untuk sepanjang tahun.
  • Rintangan:
  • ingatan saya kurang dipercayai daripada ujian unit yang kurang ditulis.
  • Tarikh akhir:
  • suatu hari. Hanya satu .
  • Kemasukan manual adalah mustahil. Rancangan Saya: Ekstrak Data dari Alat Harian Saya - Jira, Git, Slack, dan Outlook - dan menggabungkannya ke dalam masa yang komprehensif.

Alat

senjata saya:

    jira:
  1. Penjejakan tugas dan tiket.
  2. git:
  3. Sejarah komit (kerana setiap pautan jurutera yang baik berkomitmen untuk tiket, betul?).
  4. Slack:
  5. Komunikasi Pasukan (mesyuarat dan mesej termasuk).
  6. Outlook:
  7. peristiwa kalendar (kerana, ya, mesyuarat berfungsi).
Langkah 1: Mengekstrak Tiket Jira

Pertama, saya menangani Jira. Saya memerlukan semua tiket yang diberikan kepada saya dalam jangka masa tertentu. API Jira yang mantap dan sedikit sihir Python membuat ini dapat dicapai.

skrip

skrip python ini mengambil tiket JIRA:

Fungsi
<code class="language-python">import os
from jira import JIRA
import pandas as pd
from datetime import datetime
import logging
import sys
from typing import List, Dict, Any
import argparse

# ... (rest of the script remains the same) ...</code>

    Pengesahan:
  1. Menggunakan e -mel JIRA dan token API untuk pengesahan.
  2. pertanyaan jql:
  3. Membina pertanyaan JQL untuk mengambil tiket yang diberikan kepada anda dalam julat tarikh.
  4. Eksport Data:
  5. Hasil eksport ke CSV untuk analisis.
Langkah 2: Mendapatkan Git Commits

Seterusnya, saya memproses git. Oleh kerana pasukan kami termasuk ID tiket JIRA dalam mesej komit, saya membuat skrip untuk mengekstrak data komit dan menghubungkannya ke tiket.

skrip

<code class="language-python">import os
from jira import JIRA
import pandas as pd
from datetime import datetime
import logging
import sys
from typing import List, Dict, Any
import argparse

# ... (rest of the script remains the same) ...</code>

Fungsi

  1. log git: menggunakan git log untuk mengambil sejarah komit.
  2. Pengekstrakan ID Jira: menggunakan ungkapan biasa untuk mengekstrak ID tiket JIRA dari mesej komit.
  3. Eksport CSV: menjimatkan hasil ke CSV.

Langkah 3: Mengendalikan Mesej Slack

Slack terbukti lebih mencabar. Mesej adalah kaya konteks, menjadikan pemetaan tugas langsung sukar. Saya melangkaui AI (kerana kos dan kerumitan) dan mencipta tiket generik untuk masa komunikasi, kemudian menulis skrip untuk mengambil mesej Slack.

skrip

<code class="language-python">import subprocess
import csv
import re

def get_git_commits(since_date=None, author=None):
    # ... (rest of the script remains the same) ...</code>

Fungsi

  1. Senarai Perbualan: Mendapatkan semula semua saluran dan DM yang boleh diakses dengan bot.
  2. Pengambilan Mesej: Pilih mesej dalam julat tarikh yang ditentukan.
  3. Eksport CSV: Menyimpan mesej ke CSV.

Langkah 4: Menangkap mesyuarat Outlook

Akhirnya, saya menggabungkan mesyuarat. Menggunakan perpustakaan exchangelib python, saya membuat skrip untuk mengekstrak peristiwa kalendar dan mengeksportnya ke CSV.

skrip

<code class="language-python">import os
from datetime import datetime
from slack_sdk import WebClient
from slack_sdk.errors import SlackApiError
import pandas as pd

# ... (rest of the script remains the same) ...</code>

Fungsi

  1. Pengesahan: menggunakan e -mel dan kata laluan Outlook anda untuk pengesahan.
  2. pertanyaan kalendar: mengambil peristiwa kalendar dalam julat tarikh yang ditentukan.
  3. Eksport CSV: menjimatkan peristiwa ke CSV.

Apa yang seterusnya?

sekarang saya mempunyai empat fail CSV:

  1. tiket jira: semua tugas bekerja.
  2. git komited: semua kod yang ditulis.
  3. Mesej Slack: Semua komunikasi.
  4. mesyuarat Outlook: semua mesyuarat yang dihadiri.

Dalam Bahagian 2 , saya akan menunjukkan bagaimana saya menggabungkan dataset ini untuk membuat lembaran masa yang lengkap. Petunjuk: Lebih banyak python, manipulasi data, dan sentuhan sihir.

Tinggal! Ingat: Kecekapan adalah kunci.


Apakah tugas paling kurang kegemaran anda sebagai jurutera perisian? Adakah anda sudah mengautomasikannya? Kongsi pengalaman anda dalam komen!

Atas ialah kandungan terperinci Panduan Jurutera Lazy untuk Mengautomasikan Timesheets: Bahagian 1. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn