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')
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
    print('待批改的题目号:', subject_number)

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

    # 查找题目分值
    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
        print(f'第{subject_number}题的分值为:{summary_number}')

    # 随机减分
    if count <= 1:
        random_score = random.randint(1, 2)
        summary_number = str(int(summary_number) - random_score)
        print(f'第{subject_number}题随机减去{random_score}分后的分值为:{summary_number}')
    else:
        random_elements = random.sample(elements, random.randint(2, 5))
        for element in random_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
            random_score = random.randint(1, 2)
            new_summary_number = str(int(summary_number) - random_score)
            summary_element.find_element(By.TAG_NAME, 'input').send_keys(new_summary_number)
            print(f'第{subject_number}题的分值为:{new_summary_number}')

该脚本使用Selenium自动化操作浏览器,实现以下功能:

  1. 登录‘内蒙古开放大学’网站
  2. 遍历所有待批改的题目
  3. 统计每个题目对应的分值元素数量
  4. 根据分值元素数量,随机对部分分值进行减分
    • 如果分值数量小于等于1,则随机减去1-2分
    • 如果分值数量大于等于1,则随机选择2-5个分值元素进行减分,每个元素随机减去1-2分

注意:

  • 该脚本需要先安装Selenium库
  • 在使用脚本之前,请确保已经打开了Chrome浏览器,并开启调试端口(例如:start chrome --remote-debugging-port=9222 --user-data-dir="D:\评阅用"
  • 脚本中的部分代码需要根据实际情况进行调整

使用该脚本需要谨慎,请勿用于恶意目的!


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

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