早餐和午餐打卡机上会显示打卡时间的记录,在同一个excel表里,会显示工号,姓名,打卡时间的信息。本程序将每个人的打卡时间做统计,算出该员工在本月内吃过几次早餐,吃过几次午餐。
原始数据如下图所示。
初始化一个员工的类,每读取完成一个员工的数据,就将该类添加到列表里。最后将列表按照固定格式输出到excel表里。
这里打卡记录会出现“07:5812:20”这样的数据,这其实是“07:58”和“12:20”,也就是员工在“07:58”吃了早饭,在“12:20”吃了午饭。这里用正则表达式"r'\d\d:\d\d'"来匹配这个时间,若匹配到,则返回一个列表。
注意:xlrd读取excel时,只读取有效信息。例如,有10名员工(20行数据,一行姓名,一行打卡记录),若第10名员工一天都没在公司吃饭,即第20行是空行,那么xlrd只会读取19行的信息!
import re
import xlrd
import xlsxwriter
import easygui
class Staff:
def __init__(self, index, name = "", gh=0, breakfast=0, lunch=0):
self._index = index
self._name = name
self._breakfast = breakfast
self._lunch = lunch
self._sn = 0
self._department = ""
self._gonghao = gh
def _repr_(self):
return 'Staff({})'.format(self._sn)
def addBreakfast(self):
self._break