我正在开发一个面部识别和考勤系统,该系统将姓名和时间写入CSV文件,但同一个人会被多次记录

2024-05-28 23:08:17 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在开发一个面部识别和考勤系统,该系统将姓名和时间写入CSV文件。为了避免同一个人多次登录,我正在编写一个逻辑,检查姓名是否已经出现在考勤日志中,如果没有,那么出席人数就会减少。但是同一个名字被反复记录,尽管它已经被记录了一次,我无法理解这个问题

这是代码片段:

在面下方绘制一个带有名称的标签

    cv2.rectangle(frame, (left, bottom - 35), (right, bottom), (0, 0, 255), cv2.FILLED)
    font = cv2.FONT_HERSHEY_DUPLEX
    cv2.putText(frame, name, (left + 6, bottom - 6), font, 1.0, (255, 255, 255), 1)
    #markAttendance(name)
    with open('ATTLOG.csv', "r+") as g:
        myDatalist = g.readlines()
        nameList=[]
        for line in myDatalist:
            entry = line.split(',')
            nameList.append(entry[0])
            if name not in nameList:
                now=datetime.now()
                dtString = now.strftime('%H:%M:%S')
                g.writelines(f'\n{name},{dtString}')

Tags: namein系统记录linecv2leftframe
1条回答
网友
1楼 · 发布于 2024-05-28 23:08:17

您有一个逻辑错误:将整个文件读入nameList,然后检查当前名称是否在nameList第一项中。如果不是,则将其写入文件:如果当前名称稍后出现在nameList中,则将其写入,但不应写入

您需要读取整个文件,然后检查它是否在nameList中的任何位置,然后决定是否写入

对于检查,您应该使用set()-检查“is in”比使用列表快得多

already_in_file = set()
with open('ATTLOG.csv', "r") as g:       # just read
    for line in g:
        already_in_file.add(line.split(",")[0])

# process your current entry:
if name not in already_in_file:
    with open('ATTLOG.csv', "a") as g:   # append
        now = datetime.now()
        dtString = now.strftime('%H:%M:%S')
        g.writelines(f'\n{name},{dtString}')

相关问题 更多 >

    热门问题