用Python开发了一个一建、一造、二建等职考拍照搜题神器

2023-11-11 00:30

本文主要是介绍用Python开发了一个一建、一造、二建等职考拍照搜题神器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

职业考试资料包括一级建造师、一级造价师、监理工程师、消防工程师、安全工程师、消防工程师等,
职业考试不是那么容易的,要认真听课,做练习题、做模拟题、做真题、做机构押题等等。
应学生要求利用国庆假期开发了一个一建、一造、消防、二建等的拍照搜题软件,方便大家学习。
运行结果如下:

开发出来后,本以为可以识别出职考题
整题识别的开发使用有道智云拍照搜题服务的开放API,
后来打电话咨询客服,只支持k12的题库。
索性代码发出来:
登录代码:

import tkinter as tk
import tkinter.messagebox
from MainPage import MainPage


class LoginPage(object):
    def __init__(self, master=None):
        # master 画板对象,往画板上作画
        self.root = master  定义内部变量root
        self.root.geometry('%dx%d' % (300180))  设置窗口大小

        定义可以在页面更新数据的变量 普通字符串改变之后无法及时在页面中刷新
        self.username = tk.StringVar()
        self.password = tk.StringVar()

        画 内容 需要画在纸上面
        创建新的 布局控件 找一张新的纸作画
        self.page = tk.Frame(self.root)  创建Frame
        # 将控件布局到 root 对象 (GUI 程序对象)
        self.page.pack()

        self.create_page()

    def create_page(self):
        """
            使用表格布局绘制内容

        """
        #
        # tk.Label 文本框 显示文字内容
        # stick 控件对象方向 tk.W 西方位
        # pady padding y 上下的宽度
        # row 行 表格布局
        tk.Label(self.page).grid(row=0stick=tk.W)
        tk.Label(self.page, text='账户: ').grid(row=1stick=tk.W, pady=10)
        # tk.Label 输入框 显示输入内容
        输入框的文字等内容需要更新
        tk.Entry(self.page, textvariable=self.username).grid(row=1column=1stick=tk.E)
        tk.Label(self.page, text='密码: ').grid(row=2stick=tk.W, pady=10)
        tk.Entry(self.page, textvariable=self.password, show='*').grid(row=2column=1stick=tk.E)
        tk.Button(self.page, text='登陆'command=self.login_check).grid(row=3stick=tk.W, pady=10)
        tk.Button(self.page, text='退出'command=self.page.quit).grid(row=3column=1stick=tk.E)

    def login_check(self):
        """登录检测"""
        name = self.username.get()
        secret = self.password.get()
        if name == '' and secret == '':
            self.page.destroy()
            MainPage(self.root)
        else:
            tkinter.messagebox.showinfo(title='错误'message='账号或密码错误!')


if __name__ == '__main__':
    # root 对象 画板
    root = tk.Tk()
    root.title('建筑课程')
    # LoginPage 画纸
    LoginPage(root)
    # MainPage(root)
    root.mainloop()

主页界面:
import tkinter as tk
from tkinter import filedialog,messagebox,ttk
from QuestionClass import Question
import os
question = Question([], "")

class MainPage(object):
    def __init__(self, master=None):
        self.root = master  定义内部变量root
        self.root.geometry('%dx%d' % (500,300))  设置窗口大小

        self.create_page()

    def create_page(self):
        btn_get_file = tk.Button(self.root, text='选择题目图片'command=self.get_files)
        btn_get_file.grid(row=0column=0ipadx='3'ipady='3'padx='10'pady='20')
        self.text1 = tk.Text(self.root, width='40'height='10')
        self.text1.grid(row=0column=1)
        btn_get_result_path=tk.Button(self.root,text='选择搜索结果路径',command=self.set_result_path)
        btn_get_result_path.grid(row=1,column=0)
        self.text2=tk.Text(self.root,width='40'height='2')
        self.text2.grid(row=1,column=1)
        btn_sure=tk.Button(self.root,text="搜题",command=self.search_question_files)
        btn_sure.grid(row=4,column=1)
    def get_files(self):
        files = filedialog.askopenfilenames(filetypes=[("image""*.bmp"),("image""*.png"),("image""*.jpg"),])
        question.file_paths=files

        if files:
           for file in files:

            self.text1.insert(tk.END, file + '\n')
            self.text1.update()
        else:
          print('')
    def set_result_path(self):
        result_path=filedialog.askdirectory()
        question.result_path=result_path
        self.text2.insert(tk.END,result_path)

    def search_question_files(self):
        question.start_ocr()
        os.system('start '+question.result_path)





if __name__ == '__main__':
  root=tk.Tk()
  root.title("建筑课程")
  MainPage(root)

  root.mainloop()
api代码1:

from OcrQuestion import *
import os
class Question():
    def __init__(self,file_paths,result_path):
        self.file_paths=file_paths
        self.result_path=result_path

    def start_ocr(self):
        for file_path in self.file_paths:
            result=connect(file_path)
            print(file_path)
            self.save_result_format(file_path,result)
            #self.save_result(file_path,result)


    def save_result(self,file_path,result):
        result_file_name=os.path.basename(file_path).split('.')[0]+'_result.txt'
        f=open(self.result_path+'/'+result_file_name,'w',encoding='utf-8')
        f.write(str(result))
        f.close()
    def save_result_format(self,file_path,result):
        result_file_name=os.path.basename(file_path).split('.')[0]+'_result.html'
        f=open(self.result_path+'/'+result_file_name,'w',encoding='utf-8')
        result_json= json.loads(result)
        if result_json['errorCode'] == '0':
            data=result_json['data']
            questions=data["questions"]
            text=data["text"]
            f.write("题目识别:<br/>"+text)
            i=0
            for answers in questions:
                i=i+1
                subject="科目:"+answers["subject"]+"<br>"
                answer="答案:+answers["answer"]+"<br>"
                analysis="分析:"+answers["analysis"]+"<br>"
                knowledge="知识点:"+answers["knowledge"]+"<br>"
                print(subject+answer+analysis+knowledge)
                result_each="<h3>搜题结果"+str(i)+"<br></h3>"
                result_each=result_each+subject+answer+analysis+knowledge+"<br>=================这是一条分隔符============<br>"
                f.write(result_each)
        else:
            f.write("result error code:"+result_json['errorCode'])


api代码2:
import sys
import uuid
import requests
import base64
import hashlib
import json

from imp import reload


import time

reload(sys)

YOUDAO_URL = 'https://openapi.youdao.com/ocrquestionapi'
APP_KEY = 'your id'
APP_SECRET = 'your secret'


def truncate(q):
    if is None:
        return None
    size = len(q)
    return if size <= 20 else q[0:10] + str(size) + q[size - 10:size]


def encrypt(signStr):
    hash_algorithm = hashlib.sha256()
    hash_algorithm.update(signStr.encode('utf-8'))
    return hash_algorithm.hexdigest()


def do_request(data):
    headers = {'Content-Type''application/x-www-form-urlencoded'}
    return requests.post(YOUDAO_URL, data=data, headers=headers)


def connect(pic_path):
    f = open(pic_path, 'rb')  二进制方式打开图文件
    q = base64.b64encode(f.read()).decode('utf-8')  读取文件内容,转换为base64编码
    f.close()

    data = {}
    data['q'] = q
    data['signType'] = 'v2'
    curtime = str(int(time.time()))
    data['curtime'] = curtime
    salt = str(uuid.uuid1())
    signStr = APP_KEY + truncate(q) + salt + curtime + APP_SECRET
    sign = encrypt(signStr)
    data['appKey'] = APP_KEY
    data['salt'] = salt
    data['sign'] = sign

    response = do_request(data)
    result=response.content.decode('utf-8')
    print(result)
    return result

这篇关于用Python开发了一个一建、一造、二建等职考拍照搜题神器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/386326

相关文章

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

Python中的Walrus运算符分析示例详解

《Python中的Walrus运算符分析示例详解》Python中的Walrus运算符(:=)是Python3.8引入的一个新特性,允许在表达式中同时赋值和返回值,它的核心作用是减少重复计算,提升代码简... 目录1. 在循环中避免重复计算2. 在条件判断中同时赋值变量3. 在列表推导式或字典推导式中简化逻辑