一个简易问题,考勤系统必由之路,请各位大侠相助(100分)

  • 主题发起人 主题发起人 linrch
  • 开始时间 开始时间
L

linrch

Unregistered / Unconfirmed
GUEST, unregistred user!
今有一批从考勤机上取下的数据(一般是每三天采一次数据,每次有数千条记录,属于
文本格式,主要字段有CARD_ID(卡号),CHECKDATE(打卡日期),CHECKTIME(打卡时间)。
问题:
1、以编程形式把数据录入到一个新表中,以后采的数据直接点击“录入”即可连接到数据
表上去。
2、由于某些人可能在一分钟内刷多次卡,因此要只保留其中一次,其余属无效,应删除。
本人对DELPHI了解不深,希望有关键代码。

 
1.你可以循環的把文字檔一行行的寫入數據庫

2.可以判斷卡號相同的但你又不想要的可以刪除
 
发一部分数据过来,我可以帮你看看。
rabbitgg@163.net
 
re:rabbitgg
已经给你付上数据,谢谢
 
1、可以在bde中先创建一个空表,然后在程序中读入文本数据
如下例子
var
F:TextFile; 
CARD_ID:string(20);
CHECKDATE:string(20);
CHECKTIME:string(20);
begin
tbkaoqing.open;
assignfile(F.'你的文本文件名');
Reset(F);
try
while not eop(F) do
begin
tbkaoqing.insert;
tbkaoqing['CARD_ID']=CARD_ID;
tbkaoqing['CHECKDATE']=CHECKDATE;
tbkaoqing['CHECKTIME']=CHECKTIME;
end;
finally
closefile(F);
end;
end;

2、录入数据库后可以通过 table.delete 删除


 
打卡机的程序是你写吗?如果是的话你可以在那里控制,判断最近一次打卡于现在的时间差
如果不是的话就在入库时以同样的方法分析,我在指纹考勤里就是这么做的
 
我的本意是在录入的过程中删除无效的刷卡次数。
 

Similar threads

D
回复
0
查看
2K
DelphiTeacher的专栏
D
D
回复
0
查看
1K
DelphiTeacher的专栏
D
S
回复
0
查看
3K
SUNSTONE的Delphi笔记
S
S
回复
0
查看
2K
SUNSTONE的Delphi笔记
S
D
回复
0
查看
1K
DelphiTeacher的专栏
D
后退
顶部