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

# 遍历题目组,查找待批改和题号元素
elements = driver.find_elements(By.CLASS_NAME, 'card-div')
score_list = []
reduced_index_list = []  # 存储减分的题目的索引
for i, element in enumerate(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
    print('待批改的题目号:', subject_number)

    # 定位元素并统计数量
    elements = driver.find_elements(By.ID, f'subject-{subject_number}')
    count = len(elements)

    # 查找题目分值
    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)
    reduced_index_list.extend([i] * len(summary_numbers))  # 记录减分的题目的索引

# 如果只有一个题目,则对这道题的分值减去1-2分
if len(score_list) == 1:
    score_list[0] -= random.randint(1, 2)
else:
    # 随机选择2-5个题目减分
    reduce_index_list = random.sample(range(len(score_list)), random.randint(2, 5))

    # 对选择的题目减分
    for i in reduce_index_list:
        score_list[i] -= random.randint(1, 2)

# 输出减分后的分值
for i, score in enumerate(score_list):
    subject_number = reduced_index_list[i] + 1  # 使用索引获取题号
    print(f'第{subject_number}题减分后的分值为:{score}')

代码修改说明:

  1. 添加了一个 reduced_index_list 列表,用于存储减分的题目的索引。
  2. 在循环遍历题目时,将当前题目的索引添加到 reduced_index_list 列表中,以对应减分后的分值。
  3. 在输出减分后的分值时,使用 reduced_index_list[i] 获取减分题目的索引,然后使用索引获取对应的题号。

调试方法:

  1. 打印调试信息: 在代码的关键位置添加 print 语句,打印变量的值,观察数据流是否符合预期。
  2. 使用断点: 在 IDE 中设置断点,逐步执行代码,查看变量的值和程序执行流程。
  3. 检查网页元素: 使用浏览器开发者工具检查网页元素的结构和属性,确保代码中的元素定位方法是正确的。
  4. 更新代码: 如果网页内容发生了变化,需要根据网页结构更新代码中的元素定位方法和数据提取逻辑。

注意事项:

  1. 该代码仅供学习参考,请勿用于任何非法目的。
  2. 使用该代码前,请确保已了解相关法律法规和平台规则。
  3. 由于平台网页可能随时更新,该代码可能需要根据实际情况进行调整。
内蒙古开放大学自动批改工具 - Selenium脚本实现

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

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