from selenium.webdriver.chrome.options import Options
from selenium import webdriver
from selenium.webdriver.common.by import By
import time
import os
import random


def get_driver():
    # 检查是否已经打开浏览器
    browser_opened = False
    for handle in webdriver.Chrome().window_handles:
        browser_opened = True
        break

    # 创建浏览器实例或在已有浏览器中操作
    if browser_opened:
        options = Options()
        options.debugger_address = '127.0.0.1:9222'
        driver = webdriver.Chrome(options=options)
    else:
        os.system(r'start chrome --remote-debugging-port=9222 --user-data-dir="D:\评阅用"')
        options = Options()
        options.add_experimental_option('debuggerAddress', '127.0.0.1:9222')
        driver = webdriver.Chrome(options=options)

    return driver


driver = get_driver()

# 找到有‘内蒙古开放大学’字样的标签页
while True:
    for handle in driver.window_handles:
        driver.switch_to.window(handle)
        if '内蒙古开放大学' in driver.title:
            print('登录成功')
            break
    else:
        time.sleep(3)
        continue
    break

while True:
    # 等待题目组元素出现
    while True:
        try:
            elements = driver.find_elements(By.CLASS_NAME, 'card-div')
            if elements:
                break
        except:
            pass
        time.sleep(3)

    score_list = []
    subject_number_list = []
    for element in elements:
        # 查找待批改元素
        card_score_element = element.find_element(By.CLASS_NAME, 'card-score')
        if '待批改' not in card_score_element.text:
            continue
        # 查找题号元素
        subject_number_element = element.find_element(By.CLASS_NAME, 'subject-number')
        subject_number_text = subject_number_element.text
        # 提取题号
        subject_number = ''
        for char in subject_number_text:
            if char.isdigit():
                subject_number += char
        subject_number_list.append(subject_number)
        print('待批改的题目号为:', subject_number)

        # 判断是否作答
        answered = False
        elements = driver.find_elements(By.ID, f'subject-{subject_number}')
        for element in elements:
            answer_content_element = element.find_elements(By.CLASS_NAME, 'answer-content')
            if answer_content_element:
                answered = True
                break
        if not answered:
            print(f'第{subject_number}题未作答,不获取分值')
            continue

        # 查找标准答案和已经作答的元素
        standard_answer_element = None
        answered_element = None
        elements = driver.find_elements(By.ID, f'subject-{subject_number}')
        for element in elements:
            answer_content_element = element.find_elements(By.CLASS_NAME, 'answer-content')
            if answer_content_element:
                answered_element = answer_content_element[0]
            standard_answer_element = element.find_elements(By.XPATH, './/p[contains(@class,'ng-scope')]')
            if standard_answer_element:
                standard_answer_element = standard_answer_element[0]
                break

        # 如果没有标准答案的元素,则不进行对比,直接获取分值
        if not standard_answer_element:
            # 查找题目分值
            summary_numbers = []
            for element in elements:
                summary_element = element.find_element(By.CLASS_NAME, 'summary-sub-title')
                summary_text = summary_element.text
                summary_number = ''
                for char in summary_text:
                    if char.isdigit():
                        summary_number += char
                summary_numbers.append(int(summary_number))
                print(f'第{subject_number}题的分值为:{summary_number}')

            # 将题目分值存入列表
            score_list.extend(summary_numbers)
        else:
            # 获取标准答案和已经作答的内容
            standard_answer_text = standard_answer_element.text.replace(' ', '')
            answered_text = answered_element.text.replace(' ', '')
            # 如果已经作答的内容和标准答案的内容相同,则不进行减分操作
            if standard_answer_text == answered_text:
                print(f'第{subject_number}题已经作答,且作答正确,不进行减分操作')
                # 查找题目分值
                summary_numbers = []
                for element in elements:
                    summary_element = element.find_element(By.CLASS_NAME, 'summary-sub-title')
                    summary_text = summary_element.text
                    summary_number = ''
                    for char in summary_text:
                        if char.isdigit():
                            summary_number += char
                    summary_numbers.append(int(summary_number))
                    print(f'第{subject_number}题的分值为:{summary_number}')

                # 将题目分值存入列表
                score_list.extend(summary_numbers)
            else:
                # 查找题目分值
                summary_numbers = []
                for element in elements:
                    summary_element = element.find_element(By.CLASS_NAME, 'summary-sub-title')
                    summary_text = summary_element.text
                    summary_number = ''
                    for char in summary_text:
                        if char.isdigit():
                            summary_number += char
                    summary_numbers.append(int(summary_number))
                    print(f'第{subject_number}题的分值为:{summary_number}')

                # 将题目分值存入列表
                score_list.extend(summary_numbers)
                # 对选择的题目减分
                reduce_score = random.randint(1, 2)
                score_list[-1] -= reduce_score
                print(f'第{subject_number}题减{reduce_score}分,已填入{score_list[-1]}分,其他题满分')

    # 如果只有一个题目,则对这道题的分值减去1-2分
    if len(score_list) == 1:
        score_list[0] -= random.randint(1, 2)
        print(f'第{subject_number_list[0]}题减{score_list[0]}分,已填入{score_list[0]}分')
    else:
        # 随机选择2-5个题目减分
        if len(score_list) <= 5:
            reduce_num = len(score_list) - 1
        else:
            reduce_num = random.randint(2, 5)
        # 对样本数量进行判断
        if reduce_num > len(score_list) - 1:
            reduce_num = len(score_list) - 1
        elif reduce_num < 0:
            reduce_num = 0
        reduce_index_list = random.sample(range(len(score_list)), reduce_num)

        # 对选择的题目减分
        for i in reduce_index_list:
            subject_number = subject_number_list[i]
            reduce_score = random.randint(1, 2)
            score_list[i] -= reduce_score
            print(f'第{subject_number}题减{reduce_score}分,已填入{score_list[i]}分,其他题满分')

    # 将分值填入分值框中
    for i, subject_number in enumerate(subject_number_list):
        elements = driver.find_elements(By.ID, f'subject-{subject_number}')
        for element in elements:
            score_element = element.find_element(By.NAME, 'score')
            score_element.clear()
            score_element.send_keys(str(score_list[i]))
            time.sleep(0.5)

    # 等待提交成功
    while True:
        try:
            driver.find_element(By.CLASS_NAME, 'toast-message')
            time.sleep(1)
        except:
            break

    # 点击下一个学生
    next_student_element = driver.find_element(By.CLASS_NAME, 'icon-student-right-narrow')
    if 'unclickable' in next_student_element.get_attribute('class'):
        print('已经到最后一个学生')
        break
    else:
        next_student_element.click()
        time.sleep(3)
自动化批改系统:基于Selenium的在线考试评分脚本

原文地址: https://www.cveoy.top/t/topic/f0sm 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录