Greasy Fork

Greasy Fork is available in English.

hbjs质量技术网络学习助手

答题进度提示,答案备份和恢复

// ==UserScript==
// @name         hbjs质量技术网络学习助手
// @namespace    x_jianp
// @version      2025
// @description  答题进度提示,答案备份和恢复
// @author       x_jianp
// @match        *://mis.hebjs.com.cn:9011/Technic/Exam/*
// @match        *://nxb.hebjs.com.cn/paper/toExamPaperRecord/*
// @match        *://nxb.hebjs.com.cn/front/*
// @grant        unsafewindow
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_listValues
// @grant        GM_deleteValue
// @require      http://code.jquery.com/jquery-latest.js
// ==/UserScript==
// 本脚本发布地址在 http://greasyfork.icu/zh-CN/scripts/435675

//2024 需更改edge或chrome的插件管理器,打开开发者模式。
//更正match网络,让插件使用更精准。
//增加智学苑答题提示系统。不增加加速


(function () {
    'use strict';

    // 获取当前页面的URL
    const url = window.location.href;

    // 根据不同的网址执行不同的逻辑
    if (url.includes('mis.hebjs.com.cn:9011/Technic/Exam/')) {
        // 对 mis.hebjs.com.cn:9011/Technic/Exam/  的处理
        // 答题辅助
        getrecord();
        setanswer();
    } else if (url.includes('nxb.hebjs.com.cn/paper/toExamPaperRecord')) {
        // 对 内训宝答案凝练 的处理
        nxbshowanswer();
        //    } else if (url.includes('example3.com')) {
        // 对 example3.com 的处理
        //handleExample3();
    } else {
        // 默认处理
        handleDefault();
    }

    // 定义不同的处理函数
    function getrecord() {
        console.log('答题辅助系统启动');
        // 在这里添加针对 example1.com 的具体逻辑

        //成绩进度查询
        //
        //在"/Technic/Exam/AnswerNotes/ListAsJson?UnitId=1&&rows=200"文件中有全部答题记录。
        //1.读取JSON,处理数据
        //2.便历页面中的试卷名称,添加年度标识图标,实现鼠标on事件,显示成绩。


        //在规范答题的时候刷新成绩,不再做存储。
        let myJson = new Object;
        let yanzheng = null;
        try {
            yanzheng = document.querySelector("#formMain > table > tbody > tr:nth-child(1) > td > h3");
        } finally {}
        if (yanzheng != null) {
            if (yanzheng.innerText = '请选择规范开始答题') {
                // alert("新成绩读入开始工作");
                console.log("成绩读取开始");
                //let keys = GM_listValues();
                //for (let key of keys){ GM_deleteValue(key);}
                var xmlhttp = new XMLHttpRequest();
                xmlhttp.onreadystatechange = function () {
                    if (this.readyState == 4 && this.status == 200) {
                        //GM_setValue('chengji',this.responseText);
                        myJson = JSON.parse(this.responseText).rows;
                        //chengji = myJson.rows;
                        //console.log(myJson);
                        for (let j = 0; j < 6; j++) {
                            let tiku = document.querySelector("#formMain > table > tbody > tr:nth-child(" + String(j * 2 + 3) + ") > td");
                            let tishu = tiku.children.length;
                            for (let i = 0; i < tishu; i++) {
                                //innerText 将取回文字中的两个空格,精简成了一个。造成部分试卷成绩查询失败。原因是innerText是基于浏览器显示的,会基于CSS,性能比不上textContent。
                                //                            let tiname = tiku.children[i].querySelector("span > span.l-btn-text").innerText;
                                let tiname = tiku.children[i].querySelector("span > span.l-btn-text").textContent;
                                //筛选数据.
                                let chengji = myJson.filter(function (e) {
                                    return e.BankName.value == tiname
                                });
                                //console.log(chengji);
                                let years = {};
                                if (chengji.length != 0) {
                                    for (let k = 0; k < chengji.length; k++) {
                                        var year = chengji[k].CreatedDate.split("-")[0];
                                        years[year] = year;
                                        //console.log(years);
                                    }
                                    for (var key in years) {

                                        var imgy = document.createElement("img");

                                        switch (key) {
                                        case "2020":
                                            imgy.src = "https://img1.imgtp.com/2022/08/23/lMc5hns8.svg";
                                            break;
                                        case '2021':
                                            imgy.src = "";
                                            break;
                                        case '2022':
                                            imgy.src = "";
                                            break;
                                        case '2023':
                                            imgy.src = "";
                                            break;
                                        case '2024':
                                            imgy.src = "";
                                            break;
                                        case '2025':
                                            imgy.src = ""
                                            break;
                                        default:
                                            var btn = document.createElement("button");
                                            var btt1 = document.createTextNode(years[key]);
                                            btn.appendChild(btt1);
                                            tiku.children[i].appendChild(btn);
                                        }
                                        tiku.children[i].appendChild(imgy);
                                    }
                                } else {
                                    console.log(tiname + "没成绩");
                                }
                            }
                        }
                    }
                };
                xmlhttp.open("GET", "/Technic/Exam/AnswerNotes/ListAsJson?UnitId=1&&rows=200", true);
                xmlhttp.send();
            }
        }
        //成绩查询结束===========================================

    }

    function setanswer() {
        console.log('答案恢复系统启动');
        // 答题助手
        jQuery(function () {});

        try {
            var myFormDoc = document.getElementById("formMain").children[11].children[0]; //页面结构变了的时候,注意这里
        } catch (e) {}
        finally {}
        if (myFormDoc != null) {
            var qnum = (myFormDoc.children.length - 3) / 2;
            var butt = $('<a/>', {
                'id': 'upAnswer',
                'href': 'javascript:void(0)',
                'onclick': 'up_myanswer()'
            }).text('答案恢复');
            /*        var dbutt = $('<a/>',{
            'id': 'downAnswer',
            'href':'javascript:void(0)',
            'onclick':'down_myanswer()'
            }).text('      答案导出');*/

            unsafeWindow.up_myanswer = function up_myanswer() {
                alert("该插件仅用于答题暂停时,答案备份和恢复,请正规使用。规范学习");
                console.log("btn_ok");
                
                var dateNow = new Date();
                let timerp = GM_getValue('timer');
                if (timerp == undefined) {
                    var dataTime = new Date("1984-1-1");
                } else {
                    dataTime = new Date(timerp)
                };
                var timeDiff = dateNow.getTime() - dataTime.getTime();
                if (timeDiff > 15*60*1000) {
                //if (timeDiff > 60) {
                    GM_setValue("timer", dateNow.toUTCString());
                    var mytxt = document.getElementById("myinputAnswer").value.split("\n");
                    if (mytxt.length != 0) {
                        try {
                            for (var i = 0; i < mytxt.length; i++) {
                                document.getElementById(String(i) + "_MyAnswer").value = mytxt[i];
                                var iqus = mytxt[i].split(';');
                                var qusid = document.getElementById(String(i) + "_QuestionId").value; //更正题库答案的时候会影响QUSID的数值,不再是连续的,所以每次都需要读取ID来继续分步。这意味着以前的答案可能拿不了满分
                                for (var j = 0; j < iqus.length; j++) {
                                    try {
                                        document.getElementsByName(String(i) + "_MyAnswerItem_" + String(qusid))[j].value = iqus[j];
                                    } catch (e) {}
                                    finally {}
                                    //console.log(String(i)+"_MyAnswerItem_"+String(qstarnum + i));
                                    //console.log(document.getElementById(String(i)+"_MyAnswerItem_"+String(qstarnum + i)));
                                }
                                //document.getElementById(String(i)+"_MyAnswer").type=""; //显示答案统计信息
                            }
                        } catch (e) {}
                        finally {}
                    }
                } else {
                    alert("两次答题时间间隔未满15分钟,请保持克制~!!");
                };
            }

            unsafeWindow.down_myanswer = function down_myanswer() {
                var mytxt = ""
                    for (var i = 0; i < qnum; i++) {
                        mytxt += document.getElementById(String(i) + "_MyAnswer").value + "\n";
                    }
                    document.getElementById("myinputAnswer").value = mytxt;
            }

            $("#formMain").append(butt);
            //        $('#formMain').append(dbutt);
            $('#formMain').append('<textarea id="myinputAnswer"></textarea>');
        }
        //$('#formMain').append('<button id="upanswer_btn">上传答案</button>');
        /*
        for (var i=0;i<qnum;i++)
    {
        document.getElementById(String(i)+"_MyAnswer").type="text";
        }
         */
        //document.getElementById("formMain").appendChild(btn);
    }

    function nxbshowanswer() {
        console.log('内训宝答案处理');
        const correctAnswers = [];

        // Function to extract correct answers
        function extractCorrectAnswers() {
            // Select all question items
            const questionItems = document.querySelectorAll('.p-q-item');
            questionItems.forEach((item, index) => {
                // Check if it's a multiple choice question
                const correctAnswer = item.querySelector('.p-ques-score .c-green').textContent.trim();
                correctAnswers.push({
                    question: index + 1,
                    answer: correctAnswer
                });
            });

            // Display the results
            //console.log(correctAnswers.join('\n'));
            //alert(correctAnswers.join('\n'));
        }
        // Function to display the answers at the top of the page
        function displayAnswers() {
            // Create a new div element for the answers
            const answersDiv = document.createElement('div');
            answersDiv.id = 'answersDiv';
            //answersDiv.style.position = 'fixed';
            answersDiv.style.top = '0';
            answersDiv.style.left = '0';
            answersDiv.style.right = '0';
            answersDiv.style.backgroundColor = '#f8f9fa';
            answersDiv.style.padding = '10px';
            answersDiv.style.zIndex = '1000';
            answersDiv.style.textAlign = 'left';
            answersDiv.style.fontSize = '16px';
            answersDiv.style.color = '#343a40';

            // Format the answers
            let formattedAnswers = '<strong>Correct Answers:</strong><br>';
            let currentLine = '';
            let count = 0;

            correctAnswers.forEach((answer, i) => {
                if (answer.answer.includes(',')) { // Multi-select question
                    if (count > 0) {
                        formattedAnswers += `${(Math.floor(i / 5) + 1) * 5}-${i + 1}: ` + currentLine + '<br>';
                        currentLine = '';
                        count = 0;
                    }
                    formattedAnswers += `${answer.question}: ${answer.answer}<br>`;
                    count = 0;
                } else { // Single-choice question
                    currentLine += `${answer.answer} `;
                    count++;
                    if ((i + 1) % 5 === 0 || i === correctAnswers.length - 1) {
                        formattedAnswers += `${i - 3}-${i + 1}: ` + currentLine + '<br>';
                        currentLine = '';
                        count = 0;
                    }
                }
            });

            // Set the inner HTML of the div to be the answers
            answersDiv.innerHTML = formattedAnswers;
            // Prepend the div to the body so it appears at the top
            document.body.prepend(answersDiv);
        }

        // Run the extraction function and then display the answers
        extractCorrectAnswers();
        displayAnswers();
    }

    function handleDefault() {
        console.log('正在处理其他网址');
        // 在这里添加默认的处理逻辑
    }
})();