Warning: fopen(/www/sites/update.greasyfork.icu/index/store/forever/896dca54735f8d1d38f48dac5466b8e2.js): failed to open stream: No space left on device in /www/sites/update.greasyfork.icu/index/scriptControl.php on line 65
// ==UserScript==
// @name 方正教务快速查询绩点
// @namespace http://tampermonkey.net/
// @version 2024-09-07
// @description 快速在方正教务系统查询绩点
// @author https://github.com/Xlawy/GPA_Cal_FangZheng
// @match https://jwgl.cug.edu.cn/jwglxt/cjcx/*
// @icon 
// @grant GM_addElement
// @run-at document-idle
// @license MIT
// @downloadURL none
// ==/UserScript==
(function() {
'use strict';
// BEGIN添加文本提示
// 创建一个 span 元素
var newSpan = document.createElement('span');
newSpan.textContent = 'GPA计算方法:先选择对应的学年和学期,再点击查询,然后点击GPA按钮和平均分按钮即可计算。'; // 设置新的文本内容
// 找到目标 label 元素
var labelElement = document.querySelector('.col-sm-12.control-label.align-left');
// 创建一个包含换行的文本节点
var lineBreakNode = document.createElement('br');
// 将空格和换行插入到目标元素中
labelElement.appendChild(lineBreakNode);
// 将新的 span 元素添加到 label 中
labelElement.appendChild(newSpan);
//BEGIN添加文本提示
// 创建一个 span元素放置去除任选提示语
var tipsSpan = document.createElement('span');
tipsSpan.textContent = '等级制换算:优秀=95,良好=85,中等=75,及格=65'; // 设置新的文本内容
// 创建一个包含换行的文本节点
var lineBreakNode2 = document.createElement('br');
// 将空格和换行插入到目标元素中
labelElement.appendChild(lineBreakNode2);
// 将新的 span 元素添加到 label 中
labelElement.appendChild(tipsSpan);
// END添加文本提示
// BEGIN确定结果显示位置
// 创建一个包含文本的容器 div
var containerDiv = document.createElement('div');
containerDiv.style.textAlign = 'center'; // 设置文本居中
// 创建一个 span 元素放置 GPA 提示
var gpaSpan = document.createElement('span');
gpaSpan.style.color = 'red'; // 设置字体颜色为红色
// 创建一个 span 元素放置平均分提示
var aveScoreSpan = document.createElement('span');
aveScoreSpan.style.color = 'red'; // 设置字体颜色为红色
// 创建一个 span 元素放置去掉任选 GPA 提示
var removeOptionalGpaSpan = document.createElement('span');
removeOptionalGpaSpan.style.color = 'red'; // 设置字体颜色为红色
// 创建一个 span 元素放置去掉任选平均分提示
var removeOptionalAvgScoreSpan = document.createElement('span');
removeOptionalAvgScoreSpan.style.color = 'red'; // 设置字体颜色为红色
// 将每个 span 元素添加到容器 div 中
containerDiv.appendChild(gpaSpan);
containerDiv.appendChild(document.createElement('br')); // 添加换行
containerDiv.appendChild(aveScoreSpan);
containerDiv.appendChild(document.createElement('br')); // 添加换行
containerDiv.appendChild(removeOptionalGpaSpan);
containerDiv.appendChild(document.createElement('br')); // 添加换行
containerDiv.appendChild(removeOptionalAvgScoreSpan);
// 将容器 div 添加到目标元素中
labelElement.appendChild(containerDiv);
// END确定结果显示位置
var selectElement = document.querySelector('.ui-pg-selbox');
// 模拟点击下拉框
selectElement.click();
// 设置要选中的值
var valueToSelect = '100';
// 遍历下拉框中的选项并选中指定的值
var options = selectElement.options;
for (var i = 0; i < options.length; i++) {
if (options[i].value === valueToSelect) {
options[i].selected = true;
break;
}
}
// 触发 change 事件以模拟选中
selectElement.dispatchEvent(new Event('change'));
// END修改下拉框默认值
// 创建一个计算GPA按钮元素
var GPAbutton = document.createElement('button');
// button.innerHTML = 'GPA计算'; // 设置按钮文本
// 创建两个包含文本的 span 元素
var GPAbuttonText = document.createElement('span');
GPAbuttonText.textContent = 'GPA = NaN'; // 设置按钮文本内容
// 设置文本大小的样式
GPAbuttonText.style.fontSize = '10px'; // 设置文本大小为 16 像素
// 将包含文本的 span 元素添加到按钮中
GPAbutton.appendChild(GPAbuttonText);
GPAbutton.className = 'btn btn-primary btn-sm';
// 找到目标元素
var targetElement = document.querySelector('.col-md-4.col-sm-5');
// 将按钮添加到目标元素中
targetElement.appendChild(GPAbutton);
GPAbutton.addEventListener('click', function() {
// 存储学分的数组
var creditArray = [];
// 储存成绩的数组
var scoreArray = [];
// 储存学分绩点的数组
var pointArray = [];
// 储存课程性质
var propertyArray = [];
var pointSum = 0;
var creditSum = 0;
// 在按钮被点击时执行的操作
console.log('按钮被点击了!');
console.log(document);
// 查找所有具有 aria-describedby="tabGrid_cj" 属性的元素
// 遍历每个匹配的元素,并将内容添加到数组中,这里求的是学分
var elements = document.querySelectorAll('td[aria-describedby=tabGrid_xf]');
elements.forEach(function(element) {
var titleValue = element.textContent;
var trElement = element.parentNode;
// 获取上一层 元素的 style 属性
var trStyle = trElement.getAttribute('style');
// 输出上一层
元素的 style 属性
//这样式标签是红色的处理挂科成绩
if (trStyle == 'color:red') return
creditSum += parseFloat(titleValue);
creditArray.push(titleValue);
});
console.log('creditSum 属性值为: ', creditSum);
// 遍历每个匹配的元素,并将内容添加到数组中,这里求的是学分绩点
elements = document.querySelectorAll('td[aria-describedby=tabGrid_xfjd]');
elements.forEach(function(element) {
var titleValue = element.textContent;
var trElement = element.parentNode;
// 获取上一层
元素的 style 属性
var trStyle = trElement.getAttribute('style');
// 输出上一层
元素的 style 属性
if (trStyle == 'color:red') return
pointSum += parseFloat(titleValue);
pointArray.push(titleValue);
});
// 遍历每个匹配的元素,并将内容添加到数组中,这里求的是课程性质
elements = document.querySelectorAll('td[aria-describedby=tabGrid_kcxzmc]');
elements.forEach(function(element) {
var titleValue = element.textContent;
var trElement = element.parentNode;
// 获取上一层
元素的 style 属性
var trStyle = trElement.getAttribute('style');
// 输出上一层
元素的 style 属性
if (trStyle == 'color:red') return
propertyArray.push(titleValue);
});
console.log('pointSum 属性值为: ', pointSum);
var gpa = pointSum / creditSum;
// var ave_score=scoreSum / creditSum;
var gpa2 = gpa.toFixed(2);
console.log('gpa 属性值为: ', gpa2);
// alert('gpa = ' + gpa2);
GPAbuttonText.textContent = 'GPA = ' + gpa2 //+'平均分='+ave_score;
//计算平均成绩的按钮
i = 0;
creditSum = 0;
for (let i = 0; i < creditArray.length; i++) {
// 将字符串转换为浮点数并累加到总和
creditSum += parseFloat(creditArray[i]);
}
var scoreSum = 0;
// 遍历每个匹配的元素,并将内容添加到数组中,这里求的是成绩与学分的积
elements = document.querySelectorAll('td[aria-describedby=tabGrid_cj]');
elements.forEach(function(element) {
var titleValue = element.textContent;
var trElement = element.parentNode;
// 获取上一层
元素的 style 属性
var trStyle = trElement.getAttribute('stye');
// 输出上一层
元素的 style 属性
//这样式标签是红色的处理对应挂科成绩
if (trStyle == 'color:red') return
//将五级制分数转换为百分制
if (titleValue == '优秀') {
scoreSum += 95 * creditArray[i];
scoreArray.push(95);
} else if (titleValue == '良好') {
scoreSum += 85 * creditArray[i];
scoreArray.push(85);
} else if (titleValue == '中等') {
scoreSum += 75 * creditArray[i];
scoreArray.push(75);
} else if (titleValue == '及格') {
scoreSum += 65 * creditArray[i];
scoreArray.push(65);
} else {
scoreSum += parseFloat(titleValue) * creditArray[i];
scoreArray.push(titleValue);
}
console.log('分数与学分: ', titleValue, creditArray[i]);
i++;
});
console.log('scoreSum 属性值为: ', scoreSum);
var ave_score = (scoreSum / creditSum)
.toFixed(2);
console.log('平均分 属性值为: ', ave_score);
console.log('学分属性值为:', creditArray);
console.log('储存成绩的数组:', scoreArray);
console.log('储存学分绩点的数组:', pointArray);
console.log('储存课程性质:', propertyArray);
//GPAbuttonText.textContent += '平均分='+ave_score;
var removeOptionalPointSum = 0;
var removeOptionalCredit = 0;
var removeOptionalScoreSum = 0;
for (i = 0; i < propertyArray.length; i++) {
//跳过课程性质是任选的所有元素
if (propertyArray[i] != '任选') {
removeOptionalPointSum += parseFloat(pointArray[i]);
removeOptionalCredit += parseFloat(creditArray[i]);
removeOptionalScoreSum += parseFloat(scoreArray[i]) * parseFloat(creditArray[i]);
console.log('分数与学分: ', pointArray[i], creditArray[i], scoreArray[i], removeOptionalCredit, removeOptionalCredit, removeOptionalScoreSum);
}
}
// 将空格和换行插入到目标元素中
labelElement.appendChild(lineBreakNode);
// 将新的 span 元素添加到 label 中
labelElement.appendChild(newSpan);
//BEGIN添加文本提示
// 创建一个 span元素放置去除任选提示语
var tipsSpan = document.createElement('span');
tipsSpan.textContent = '等级制换算:优秀=95,良好=85,中等=75,及格=65'; // 设置新的文本内容
//BEGIN计算结果显示
// 设置每个 span 元素的文本内容
gpaSpan.textContent = 'GPA = ' + gpa2;
aveScoreSpan.textContent = '平均分 = ' + ave_score;
removeOptionalGpaSpan.textContent = '去掉任选GPA = ' + (removeOptionalPointSum / removeOptionalCredit)
.toFixed(2);
removeOptionalAvgScoreSpan.textContent = '去掉任选平均分 = ' + (removeOptionalScoreSum / removeOptionalCredit)
.toFixed(2);
//END计算结果显示
//GPAbuttonText.textContent += '去掉任选平均分=' + (removeOptionalScoreSum/removeOptionalCredit).toFixed(2)+' GPA='+ ( removeOptionalPointSum/removeOptionalCredit).toFixed(2);
});
})();