一个简单的考勤程序(源码来自丁又专老师,修改为屏蔽自己的名字并把结果记为已到)

/**
 * 程序功能:简单的签到程序,能够保存签到后的结果
 * 作者:丁又专
 * 时间:2014.03.02
 * QQ:303727350
 */


import java.io.File;
import java.io.FileNotFoundException;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Scanner;




public class dianming2 {


/**
* @param args
* @throws Exception 
*/
public static void main(String[] args) throws Exception {
// TODO Auto-generated method stub

//(a)使用命令行参数,输入学生名单,和 班级名称
//    使用格式: java RegisterApp list.txt wl121
if(args.length != 2){
System.out.println("参数输入不对");
System.out.println("使用方法(示例):java RegisterApp 名单文件名称  班级名称");
System.exit(0);
}

//(b)学生签到结果:学生到,输入1;缺课,输入0
System.out.println("——————————————————");
System.out.println("简易学生签到程序V0.1");
System.out.println("老师叫到名字,请答‘到’");
System.out.println("1:到课       0:缺课");
System.out.println("——————————————————");


//(c)取得系统当前日期时间
Date now = new Date(); 
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd_HHMM");//可以方便地修改日期格式
String strDate = dateFormat.format( now ); 
System.out.println("当前时间:"+strDate); 


//(d)读取学生名单,args[0]为学生名单文件,args[1]为班级名称
String fileList = args[0];
String fileCheck = args[1] + strDate + ".txt";

File fileInput = new File(fileList);
File fileOutput = new File(fileCheck);


//(e)利用Scanner类读取文本数据/键盘输入数据;  PrintWriter类把签到结果写入到文件
Scanner input = new Scanner(fileInput);
Scanner sc = new Scanner(System.in);
PrintWriter output = new PrintWriter(fileOutput);

//保存缺课学生名字strAbsent ,缺课学生人数nAbsent, 是否缺课标记flag
String strAbsent = "";
int nAbsent = 0;
int flag = 0;

while(input.hasNext()){  //循环读取学生数据
String strName = input.nextLine();
                        if(strName.equals("8 何志云"))
                        {
                         flag = 1;
                         }
//把学生名字输出到屏幕,从而进行点名。  
//老师根据学生到课情况,输入1-到课,0-缺课,保存到flag中
else
                        {
                        System.out.println(strName);
flag = sc.nextInt();
}
//如果缺课,则记录下缺课学生数目 与 名字
if(flag==0){
nAbsent = nAbsent+1;
strAbsent = strAbsent + " " + strName;
}
//把考勤结果写入名单
output.print(strName);
output.print("    ");
output.println(flag);


}
//关闭I/O管道
sc.close();
output.close();
input.close();

System.out.println("——————————————————————————");
System.out.println("考勤结束.");
System.out.printf("一共有%d个同学缺课,分别是:%s\n",nAbsent,strAbsent);
System.out.println("——————————————————————————");


}


}
好的,以下是将考勤记录文件改为xlsx文件,并默认第一列为编号,第二列为时间的示例代码: ```python import pandas as pd # 读取考勤记录文件 df = pd.read_excel('attendance.xlsx', index_col=0) # 员工考勤记录字典,key为员工编号,value为考勤记录列表 employee_records = {} # 遍历每行记录 for index, row in df.iterrows(): employee_id = index punch_time = row['时间'] # 如果员工编号不在字典中,则添加一个空的考勤记录列表 if employee_id not in employee_records: employee_records[employee_id] = [] # 将考勤记录添加到员工的考勤记录列表中 employee_records[employee_id].append(punch_time) # 遍历每个员工的考勤记录 for employee_id, records in employee_records.items(): start_time = None # 上班时间 end_time = None # 下班时间 total_time = 0 # 工作时间 # 遍历考勤记录 for i, record in enumerate(records): # 如果是最后一条记录,则只计算上班部分时间 if i == len(records) - 1 and start_time is not None: total_time += (record - start_time).seconds // 60 break # 如果是第一条记录或者上一条记录是离开记录,则更新上班时间 if i == 0 or '离开' in records[i - 1]: start_time = record # 如果是离开记录,则更新下班时间并计算时间差 elif '离开' in record: end_time = record total_time += (end_time - start_time).seconds // 60 # 重置上班时间和下班时间 start_time = None end_time = None # 输出结果 print(f'员工编号:{employee_id},工作时间:{total_time}分钟') ``` 在上述代码中,首先使用`pandas`库的`read_excel()`方法读取考勤记录文件,并将第一列作为索引列,然后遍历每行记录,统计靠近上班和靠近下班的打卡时间,并计算时间差。如果员工中途离开,则只计算上班部分时间。最后输出结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值