使用 opencv 识别答题卡,生成填涂答案

本文介绍了如何利用OpenCV技术对答题卡进行预处理,包括灰度转换、黑白增强和轮廓查找,以定位选择题和判断题的黑块。然后根据黑块位置校正图像,并识别区域内的主观题答案,转化为ABCD选项。尽管初次尝试,此方法提供了解答思路,未来可通过优化提升识别准确率。
摘要由CSDN通过智能技术生成

一般答题卡设计时都在试卷4个角预留4个一样大小的黑块

仅能识别选择题判断题之类的填涂答题的题目,不能识别填空题应用题等其它主观题

使用 opencv 识别试卷图片中所有黑块,再根据黑块大小获取四个角的位置,根据四个黑块位置校正图像

将图像转成灰度图

Cv2.CvtColor(imgOrg, dst, ColorConversionCodes.BGR2GRAY);

 对图像黑白增强处理

Cv2.Threshold(dst, dst, 160, 255, ThresholdTypes.Binary);

 查找所有黑块包括黑块大小位置等信息

Cv2.FindContours(dst, out contours, out hierarchies, RetrievalModes.List, ContourApproximationModes.ApproxNone);

 查找四角黑块的位置,根据黑块位置矫正图像并分析答案

答题卡校正前图像矫正前

答题卡图像矫正后

再根据每道题的位置识别区域内涂写的答案在区域内的位置

根据答案在区域内的位置转换成A B C D选项

输出json

{"n1":"A","n2":"D","n3":"B","n4":"C","n5":"D","n6":"D","n7":"A","n8":"C","n9":"D","n10":"A","n11":"B","n12":"B","n13":"D","n14":"C","n15":"A","n16":"C","n17":"D","n18":"A","n19":"D","n20":"C","n21":"D","n22":"A","n23":"B","n24":"D","n25":"C"}

 最后再与标准答案比对计算得分。

 答题卡识别示例演示

https://d.iyanhong.com/demos/answersheetscan.html

 目前只是简单的处理识别,头一次用opencv,识别方法可能也不是太好,给可能用到的用户提供个思路,要进一步提升识别率也可以用opencv提供的其它方法处理优化图像

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值