京公网安备 11010802034615号
经营许可证编号:京B2-20210330
用excel制作考勤表
平常单位的一些进货单出库单类的表格都是用excel制作的,今天单位没有考勤表了,于是我就用excel制作考勤表,这样就不用出去买了,而且单位人也少,我就可以以后利用电子考勤表来自动计算每个人的考勤了。
1、打开一张空白的EXCEL工作表,先按下图所示画出样子。
图中M1:P1是合并单元格,用于填写“年”,S1:T1是合并单元格,用于填写“月”,为了醒目设置成浅蓝色底纹。

2、为了让第二行中的“星期”能自动显示,需要设置公式,如下:
在D2单元格中输入公式 =IF(WEEKDAY(DATE($M$1,$S$1,D3),2)=7,"日",WEEKDAY(DATE($M$1,$S$1,D3),2))
这时就能看到D2单元格中出现一个表示星期的“日”字(这说明2011年5月1号是星期日)。
公式含义:先用DATE函数把M1格中的“年”、S1格中的“月”、D3格中的“日”组成一个电脑能识别的“日期”;再用WEEKDAY函数把这个“日期”变成星期所代表的数字。
WEEKDAY函数后面加了参数“2”,是为了让星期一显示为“1”,让星期二显示为“2”...让星期日显示为“7”。
由于我们不习惯把星期日叫成“星期7”,所以最后用IF函数做判断,把显示为“7”的自动改成“日”。
提示:函数DATE与WEEKDAY在EXCEL自带的帮助中有详细的用法介绍,想了解它们的朋友可以参考。
为了方便我们中国人的习惯,还要把显示为阿拉伯小写数字的星期变成中文数字,即“星期1”变成“星期一”这种格式。这就需要通过定义单元格格式来实现。
选中D2单元格,按鼠标右键“单元格格式”,在出现的格式窗口中选“数字”选项卡,在左侧的“分类”框中选“特殊”,在右侧的“类型”框中选“中文小写数字”,按“确定”退出。

这些完成后就可以用鼠标选中D2单元格,按住它右下角的“填充柄”拖动复制AH2单元格,效果如下图:

在AI单元格中可以通过公式显示当月的总天数,公式 =DAY(DATE(M1,S1+1,1)-1)
公式含义:先由DATE函数“DATE(M1,S1+1,1)”得到本月的下一个月月初1号的日期。本例中,本月是5月份,下一月的月初一号就是6月1日。
再用减1得到本月最后一天的日期,即5月31日,最后再由DAY函数取出表示当月天数的“31”。
3、先设定一些考勤符号,放在AR列中,如图所示:

这些符号并非统一规定,可根据习惯及喜好来自己设定,也可用汉字来代表,总之自己看着习惯就行了。
怎么把这些符号方便快捷的输入到考勤表中D4:AH33区域中呢?我们采用下拉框的方法。
选中D4:AH33区域,按上面工具栏中的“数据-有效性”,弹出有效性设置对话框,选“设置”选项卡,在“允许”中选“序列”,在“来源”中点击右端的折叠按钮,然后用鼠标在表格中选取AR1:AR8区域,再次点击折叠按钮,回到有效性设置窗口,按“确定”退出。

完成后,在考勤表的D4:AH33区域中任意一个单元格选中时,都会出现一个下拉框按钮,点击按钮就弹出下拉框,可用鼠标方便的选取要输入的考勤符号。

4、考勤已经可以输入了,怎样统计每个人的出勤情况呢?还是通过公式自动来统计。
先划出一块区域来做考勤统计,如下图红圈范围:

这个区域中要设置多个合并单元格,AK4:AK5是合并的,AL4:AL5是合并的......AP4:AP5是合并的。也就是每一个姓名对应的上下两行需要合并,这样方便把上午与下午统计在一个格中。
做完AL4:AP5区域的合并操作后,选中区域右下角填充柄,按住鼠标左键向下拉动,一直到AP33单元格再松开鼠标左键,就能快速的把下面单元格分别也变成合并状态。(其实就是复制了AL4:AP5的样式)
由于第一个人的考勤记录区域是D4:AH5区域,所以需要将此区域中的考勤符号出现次数统计出来,就能知道这个人的考勤情况了。
先在AK3:AP3中输入考勤符号,然后在AK4单元格中输入公式 =COUNTIF($D4:$AH5,AK$3)
公式含义:使用COUNTIF函数统计D4:AH5区域内出现了几次AK3格中的符号。
用拖动复制功能把这个公式复制到AK4:AP4区域中。
再选中AK4:AP4区域,按住AP4右下角的填充柄向下拖动复制,一直复制到AP33单元格。
现在统计区域中的每个格都有公式了,由于公式中某些部份使用了绝对引用符号“$”,所以在拖动复制中,每个单元格的公式都是不太一样的。
提示:在这个考勤表中,多次使用了“拖动复制”方法,可以极大的简化输入公式与设置格式的操作,而且在公式中灵活使用绝对引用符号“$”,也能把有规律变化的公式快速输入到区域中,避免了逐个输入的麻烦。
现在我们看一下有统计公式的效果

在统计结果中,会有许多0值出现,表示对应的考勤符号未在考勤区域中出现,0值太多时会感觉很“乱”,我们通过设置来“隐藏”这些0值。
按工具栏中的“工具-选项”,出现选项窗口,按下图设置,去掉“零值”前的勾,就可使这些0值不显示出来。

5、到这里,考勤表基本上就完成了。细心的朋友会发现一个小问题,就是AF3、AG3、AH3这三个格中始终出现29、30、31这三个日期,即使在2月份只有28天的情况下也是如此,感到非常不爽。
我们可以用条件格式的方法来让它们自动根据月份的变化来显示或隐藏,即小月时AH3格变成空白,大月时才显示31,在二月份时如果不是闰月,就不显示AF3、AG3、AH3格中的数字。
选中AF3:AH3区域,按“格式-条件格式”,按下图设置:

用这种条件格式的方法还能设置D2:AH2区域,让它们在星期六与星期日时变成不同颜色,能更直观的显示每周情况,设置方法大家可以自己琢磨一下。
上面用excel制作考勤表的步骤基本上属于通用类型的,适合很多公司使用,大家也可以根据自己的情况个性设置。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在 MySQL 实际应用中,“频繁写入同一表” 是常见场景 —— 如实时日志存储(用户操作日志、系统运行日志)、高频交易记录(支付 ...
2025-10-30为帮助教育工作者、研究者科学分析 “班级规模” 与 “平均成绩” 的关联关系,我将从相关系数的核心定义与类型切入,详解 “数 ...
2025-10-30对 CDA(Certified Data Analyst)数据分析师而言,“相关系数” 不是简单的数字计算,而是 “从业务问题出发,量化变量间关联强 ...
2025-10-30在构建前向神经网络(Feedforward Neural Network,简称 FNN)时,“隐藏层数目设多少?每个隐藏层该放多少个神经元?” 是每个 ...
2025-10-29这个问题切中了 Excel 用户的常见困惑 —— 将 “数据可视化工具” 与 “数据挖掘算法” 的功能边界混淆。核心结论是:Excel 透 ...
2025-10-29在 CDA(Certified Data Analyst)数据分析师的工作中,“多组数据差异验证” 是高频需求 —— 例如 “3 家门店的销售额是否有显 ...
2025-10-29在数据分析中,“正态分布” 是许多统计方法(如 t 检验、方差分析、线性回归)的核心假设 —— 数据符合正态分布时,统计检验的 ...
2025-10-28箱线图(Box Plot)作为展示数据分布的核心统计图表,能直观呈现数据的中位数、四分位数、离散程度与异常值,是质量控制、实验分 ...
2025-10-28在 CDA(Certified Data Analyst)数据分析师的工作中,“分类变量关联分析” 是高频需求 —— 例如 “用户性别是否影响支付方式 ...
2025-10-28在数据可视化领域,单一图表往往难以承载多维度信息 —— 力导向图擅长展现节点间的关联结构与空间分布,却无法直观呈现 “流量 ...
2025-10-27这个问题问到了 Tableau 中两个核心行级函数的经典组合,理解它能帮你快速实现 “相对位置占比” 的分析需求。“index ()/size ( ...
2025-10-27对 CDA(Certified Data Analyst)数据分析师而言,“假设检验” 绝非 “套用统计公式的机械操作”,而是 “将模糊的业务猜想转 ...
2025-10-27在数字化运营中,“凭感觉做决策” 早已成为过去式 —— 运营指标作为业务增长的 “晴雨表” 与 “导航仪”,直接决定了运营动作 ...
2025-10-24在卷积神经网络(CNN)的训练中,“卷积层(Conv)后是否添加归一化(如 BN、LN)和激活函数(如 ReLU、GELU)” 是每个开发者都 ...
2025-10-24在数据决策链条中,“统计分析” 是挖掘数据规律的核心,“可视化” 是呈现规律的桥梁 ——CDA(Certified Data Analyst)数据分 ...
2025-10-24在 “神经网络与卡尔曼滤波融合” 的理论基础上,Python 凭借其丰富的科学计算库(NumPy、FilterPy)、深度学习框架(PyTorch、T ...
2025-10-23在工业控制、自动驾驶、机器人导航、气象预测等领域,“状态估计” 是核心任务 —— 即从含噪声的观测数据中,精准推断系统的真 ...
2025-10-23在数据分析全流程中,“数据清洗” 恰似烹饪前的食材处理:若食材(数据)腐烂变质、混杂异物(脏数据),即便拥有精湛的烹饪技 ...
2025-10-23在人工智能领域,“大模型” 已成为近年来的热点标签:从参数超 1750 亿的 GPT-3,到万亿级参数的 PaLM,再到多模态大模型 GPT-4 ...
2025-10-22在 MySQL 数据库的日常运维与开发中,“更新数据是否会影响读数据” 是一个高频疑问。这个问题的答案并非简单的 “是” 或 “否 ...
2025-10-22