美文网首页
考勤数据统计

考勤数据统计

作者: 阿发贝塔伽马 | 来源:发表于2018-01-03 21:10 被阅读0次

读取考勤数据

import pandas as pd
myKq = pd.read_excel("kq.xlsx")
myKq[u'打卡日期'].values
array([u'2017-12-29 17:33:26', u'2017-12-29 17:31:54',
       u'2017-12-29 17:28:55', ..., u'2017-01-03 17:05:55',
       u'2017-01-03 12:32:11', u'2017-01-03 10:24:25'], dtype=object)
import numpy as np
#myKq.insert(1,'city',myKq['address']) #先复制原来的列
daytime = myKq[u'打卡日期'].map(lambda x:x.split(' ')) #分别处理新旧两列
day, time = [],[]
for d in daytime:
    day.append(d[0])
    time.append(d[1])
myKq['day'] = day
myKq['time'] = time
myKq.tail()
import matplotlib.pyplot as plt
from datetime import datetime
from matplotlib.font_manager import FontProperties  
font = FontProperties(fname=r"C:\\WINDOWS\\Fonts\\simsun.ttc", size=14)

def getMin(arrtime):
    a = (arrtime).split(":")
    return (float(a[0])-9)*60+float(a[1])
plt.figure()
def getMax(arrtime):
    a = (arrtime).split(":")
    return (float(a[0])-18)*60+float(a[1])

df = myKq["time"].groupby(myKq['day'])

night = df.max().map(lambda x:getMax(x))
morning = df.min().map(lambda x:getMin(x))
colors = np.array(['g']*morning.size)
dic_c_l = {'g':'work day', 'r':'friday', 'b':'weekend'}
for index, day in enumerate(morning.index):
    week = datetime.strptime(day, '%Y-%m-%d').weekday()
    if (week+1 == 5):
        colors[index] = 'r'
    elif (week+1==6 or week+1==7):
        colors[index] = 'b'
fig = plt.figure(figsize=(14,5))
ax1 = fig.add_subplot(121)

plt.xlabel(u'上班(day)',fontproperties=font)  
plt.ylabel(u'加班时间',fontproperties=font)  

for index, value in enumerate(dic_c_l.keys()):
    temp = np.where(colors==value)
    ax1.scatter(temp, night.values[temp], c=value,marker= 'o', label= dic_c_l[value])
ax1.legend(loc='upper left')

ax2 = fig.add_subplot(122) 
ax2.hist(night, bins = 40, normed= 0)


plt.xlabel(u'加班分钟数',fontproperties=font)
plt.ylabel(u'次数',fontproperties=font)

plt.show()
fig = plt.figure(figsize=(14,5))
ax1 = fig.add_subplot(121)

colors = np.array(['g']*morning.size)
dic_c_l = {'g':'work day', 'r':'monday', 'b':'weekend'}
for index, day in enumerate(morning.index):
    week = datetime.strptime(day, '%Y-%m-%d').weekday()
    if (week+1 == 1):
        colors[index] = 'r'
    elif (week+1==6 or week+1==7):
        colors[index] = 'b'
        
plt.xlabel(u'上班(day)',fontproperties=font)  
plt.ylabel(u'迟到时间',fontproperties=font)  

for index, value in enumerate(dic_c_l.keys()):
    temp = np.where(colors==value)
    ax1.scatter(temp, morning.values[temp], c=value,marker= 'o', label= dic_c_l[value])
ax1.legend(loc='upper left')

ax2 = fig.add_subplot(122) 
ax2.hist(morning.values, bins = 80, normed= 0)


plt.xlabel(u'迟到分钟数',fontproperties=font)
plt.ylabel(u'次数',fontproperties=font)
plt.show()

相关文章

  • 考勤数据统计

    读取考勤数据

  • 工作日常二三事:考勤异常-遇事要冷静

    今天考勤数据最后结算日,结果突然发现自己还有没有处理的考勤,但是考勤统计节制日期已经过了,天啊,这代表什么?要扣钱...

  • 2019-07-12 11、考勤系统总结报告

    一、打卡考勤系统需求分析报告 打卡考勤系统需求分析报告 二、考勤系统数据库设计 考勤系统数据库设计 三、考勤系统界...

  • 钉钉办公软件

    自从公司用上了钉钉,对不同职位的员工提供了更加便捷的办公软件。 首先考勤打卡,它大大节省了人事部统计考勤数据的时间...

  • 2022.6.1

    工作:统计考勤并上报。编写日报并上报。统计完成考勤并上报。报销交给李忠亮带给陈总签字。落实纪要完成情况。填写项目情...

  • 2022.4.30

    工作:统计考勤,编写日报并上报。编写个人月总结并上报。收集项目部成员月总结并上报。收集项目部成员考勤并进行统计。与...

  • POI之考勤统计

    需求分析 我们公司考勤使用指纹打卡,出入公司也需要指纹打卡开门,这样每个人每天打卡记录全在考勤系统里面,这个考勤系...

  • 在家办公统计考勤

    今天继续宅在家统计公司考勤,询问每个员工考勤情况,休假,请假,值班,离职,入职,为最终的工资计算提供依据。 疫情蔓...

  • 2022.11.1

    工作:统计考勤并上报。编写日报并上报(临时设施10月底已完成,日报里面零星的工程不再体现)。考勤统计完成并扫描压缩...

  • MFC开发员工管理系统,附C++源码!

    在一些人数规模比较大的企业,员工的考勤统计可谓是人事部门月底最头疼的一件事情,需要先从考勤机里面把数据导出来,还有...

网友评论

      本文标题:考勤数据统计

      本文链接:https://www.haomeiwen.com/subject/ttjpgxtx.html