利用python整理出勤记录表

早餐和午餐打卡机上会显示打卡时间的记录,在同一个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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值