方正教务快速查询绩点

快速在方正教务系统查询绩点

// ==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
// ==/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;

			// 获取上一层 <tr> 元素的 style 属性
			var trStyle = trElement.getAttribute('style');
			// 输出上一层 <tr> 元素的 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;

			// 获取上一层 <tr> 元素的 style 属性
			var trStyle = trElement.getAttribute('style');
			// 输出上一层 <tr> 元素的 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;

			// 获取上一层 <tr> 元素的 style 属性
			var trStyle = trElement.getAttribute('style');
			// 输出上一层 <tr> 元素的 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;

			// 获取上一层 <tr> 元素的 style 属性
			var trStyle = trElement.getAttribute('stye');
			// 输出上一层 <tr> 元素的 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);
	});
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址