DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: wugangbest
今日帖子: 26
在线用户: 18
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 qwert8008 (angel) ★☆☆☆☆ -
普通会员
2019/1/14 16:04:50
标题:
考勤统计,小问题,请高手不吝赐教。 浏览:1166
加入我的收藏
楼主: 2018-12-31     戊
2019-01-01     甲
2019-01-02     乙
2019-01-03     丙
2019-01-04     丁
2019-01-05     戊
..
..
2019-01-31     甲

 甲乙丙丁戊每个人上一天班,每个人每天连着上1个中班(18:00-24:00)和1夜班(24:00-8:00);计为1个中班加1个夜班,但是1月份考勤总体统计的时候,2018-12-31  戊上的夜班(24:00-8:00)应计入1月份。也就是说戊1月份应多加1个夜班,同理,月底2019-01-31  甲的夜班(24:-8:00)应算作2月份的考勤,1月份甲应减去一个夜班。像这样每个月的准确考勤代码应该怎么写呢,请高手解答??
----------------------------------------------
-
作者:
男 lwcvod (lwcvod) ★☆☆☆☆ -
普通会员
2019/1/14 16:31:29
1楼: 考勤的这个东西很搞,搞的头疼为止,最后还搞不出来
----------------------------------------------
Delphi
作者:
男 lwcvod (lwcvod) ★☆☆☆☆ -
普通会员
2019/1/14 16:32:35
2楼: 如果某一天,这个人,加班到第2天,9点下班,请问9点打卡算个啥,上班还是下班,如果这个人昨天下班忘记打卡,第2天9点上班,请问这个算上班迟到还是下班?
----------------------------------------------
Delphi
作者:
男 bahamut8348 (leonna) ★☆☆☆☆ -
普通会员
2019/1/14 17:31:39
3楼: 考勤是最难搞的系统。尤其是多段排班的。
一般就是限定一个打卡时间。不在打卡时间内的算缺卡,缺卡就算缺勤。
----------------------------------------------
--
作者:
男 wang_80919 (Flying Wang) ★☆☆☆☆ -
普通会员
2019/1/14 17:52:35
4楼: 所以,软件上,还得加 补充考勤信息的功能。
单独为某些没打卡的,补充。
----------------------------------------------
(C)(P)Flying Wang
作者:
男 qwert8008 (angel) ★☆☆☆☆ -
普通会员
2019/1/14 18:50:22
5楼: 各位,不要想复杂了,我只要我贴子描述的功能,别的功能不要,就是要统计中夜班数,假设都正常上班,甲乙丙丁戊按顺序轮流上班
----------------------------------------------
-
作者:
男 hjandy (andy) ★☆☆☆☆ -
普通会员
2019/1/14 19:56:06
6楼: 考勤信息 不要只用时间比对,加上考勤日期,上面你讲的主要是跨日考勤, 如2018-12-31 23:xx - 2019-01-01 8:00 归 考勤日2018-12-31, 你上面才两个班有跨日, 如果计四班交错上,真假帐更不用做了。  
如果区分上月、本月已计考勤比如加个考勤日或标识T/F或年月记录就可以了
比如计前用名单和班次转成名单将考勤上下班时间替上去,不过要设计算规则
----------------------------------------------
andy
作者:
男 dlfsystem (dlfsystem) ★☆☆☆☆ -
盒子活跃会员
2019/1/14 20:15:21
7楼: 你都知道如何计算过程了,代码还写不出来吗!
----------------------------------------------
-
作者:
男 vkow (vkow) ★☆☆☆☆ -
普通会员
2019/1/14 21:30:43
8楼: 我猜,你这一辈子也统计不出来。

原因,就是你的数据不完整。你仅仅记录了上班日期,却没记录上班时间。无法区分中班和夜班。这是个无解的题。
----------------------------------------------
-
作者:
男 ghs_79 (ghs) ★☆☆☆☆ -
盒子活跃会员
2019/1/15 7:57:16
9楼: 1、加班也要按点打卡。
2、加班情况,可以增加加班打卡功能。
3、或者先处理数据,把数据加工规范了再统计,比如加班,先分解成正常下班,再加班。
----------------------------------------------
Delphi爱好者。
作者:
男 inbreak (入侵) ★☆☆☆☆ -
盒子活跃会员
2019/1/15 8:48:31
10楼: 人家都说,不要想复杂了,,。。

如:2018-12-31  戊上的夜班(24:00-8:00),当成 2019-1-1的考勤是吧。

1、那他的出勤打卡时间应该是:
  2019-01-01 00:00:00 
  2019-01-01 08:00:00
  这本身就是 2019-01-01 的日期呀,

2、就算你的考勤钟特别点为记录为:
  2018-12-31 24:00:00 
  2018-12-31 08:00:00
  那你就先判断出勤始:时间是大于等于24:00:00且出勤终是小于等于08:00:00且该日期是本月的最后一天[ 最简单的得到本月最后一天的方法,如: EncodeDate(2019,1,1)-1,也就是某月的第一天减去1天就好,这样就不用判断大小月平润月了 ]


就象我记录工厂的生产日报表一样。记录字段一班会是:例:

工号   条码         生产日期     实际开工始          实际开工止
0001   2018010101   2018-11-30   2018-12-01 00:00:00  2018-12-01 08:00:00

在员工扫码录入时,我就得到他们的 超始时间,如果是小于8点,然后再判断他的班次。如果是夜班的,那就自动将生产日期记录为  实际开工始的前一天。即 2018-11-30
----------------------------------------------
我是菜鸟,己经搞了十多年了,但是我仍然很菜。
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行62.5毫秒 RSS