你需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
你需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
你需要先安装一款用户样式管理器扩展(如 Stylus)后才能安装此样式。
你需要先安装一款用户样式管理器扩展后才能安装此样式。
你需要先安装一款用户样式管理器扩展后才能安装此样式。
你需要先安装一款用户样式管理器扩展后才能安装此样式。
(我已安装用户样式管理器,立即安装用户样式!)
// ==UserScript==
// @name 杭电信工教务成绩分析
// @namespace https://chiyukiruon.com
// @version 1.0.1
// @description 用于分析杭电信工教务的详细成绩并展示
// @author ChiyukiRuon
// @source https://chiyukiruon.com
// @license GNU General Public License
// @supportURL https://github.com/ChiyukiRuon/hziee-score-detail-js/issues
// @match http://10.130.5.235:6379/*
// @match http://10.130.5.236/*
// @match http://10.130.5.229:6379/*
// @icon 
// @grant GM_addStyle
// ==/UserScript==
(function() {
'use strict';
var css = `table {border-collapse: collapse;width: 100%;} table, th, td {border-bottom: 1px solid rgb(236, 238, 244);} table tr:nth-child(even) {background-color: rgb(250, 250, 250);} table tr:nth-child(odd) {background-color: rgb(255, 255, 255);} .main-table:hover {background-color: rgb(245, 247, 250)} .table-text {margin-left: 10px}`
GM_addStyle(css)
// 版权及版本信息
console.log("\n _____ _ _ _ _ \n" +
" / ____| | (_) | | (_)\n" +
" | | | |__ _ _ _ _ _| | ___ \n" +
" | | | '_ \\| | | | | | | | |/ / |\n" +
" | |____| | | | | |_| | |_| | <| |\n" +
" \\_____|_| |_|_|\\__, |\\__,_|_|\\_\\_|\n" +
" __/ | \n" +
" |___/ \n" +
"详细成绩分析插件-v1.0.1\n" +
"Copyright©ChiyukiRuon\n" +
"https://chiyukiruon.com")
function isCredits(num) {
const regex = /^(\d|\d\.\d|\.\d|\d\.)$/
return num.match(regex) !== null && num !== 0
}
function isFinalScore(list, index) {
const keywords = ['不及格', '不合格', '合格', '及格', '良好', '中等', '优秀',]
const nextIndex = index + 1
const currentElement = list[index]
const nextElement = list[nextIndex]
if (!nextElement) {
if (/^\d{2}$/.test(currentElement)) {
return true
}
return keywords.includes(currentElement)
}
return !!(currentElement !== '是' && (nextElement === '是' || /(学院|学部)/.test(nextElement)))
}
function isPass(score) {
if (/^\d{2}$/.test(score)) {
return Number(score) >= 60
}else {
const keywords = ['合格', '及格', '良好', '中等', '优秀',]
return keywords.includes(score)
}
}
function passNum(list) {
let num = 0
for (let i in list) {
if (list[i].isPass) {
num++
}
}
return num
}
function base64ToString(base64String) {
let normalString = ''
if (base64String === '') {
return
}
try {
normalString = new TextDecoder().decode(Uint8Array.from(atob(base64String), (c) => c.charCodeAt(0)))
} catch (e) {
return
}
return normalString
}
function siftString(string) {
const regex = /[\u4e00-\u9fa5a-zA-Z0-9\-()().+\s]+(?=dd)/g;
const result = string.match(regex).map(str => str.replace(/dd$/, ''));
splitCourse(result)
return splitCourse(result)
}
function splitCourse(courseList) {
const regex = /([\d-]+)-[a-zA-Z0-9-]+-\d+/;
const result = [];
let currentSection = [];
for (let i = 0; i < courseList.length; i++) {
const item = courseList[i];
const match = item.match(regex);
if (match) {
if (currentSection.length > 0) {
result.push(currentSection);
currentSection = [];
}
}
currentSection.push(item);
}
if (currentSection.length > 0) {
result.push(currentSection);
}
return formatResultData(result);
}
function formatResultData(courseList) {
const resultList = []
for (let i = 1;i < courseList.length;i++) {
const item = {}
const assessmentScore = []
for (let j = 0;j < courseList[i].length;j++) {
let courseListItem = courseList[i]
if (j === 0) {
item.courseId = courseListItem[j]
}
if (j === 4) {
item.courseName = courseListItem[j].trimStart().replace(/^\d/g, "")
}
if (isCredits(courseListItem[j]) && j > 4) {
item.credits = courseListItem[j].trimStart()
}
if (j > 6 && courseListItem[j] !== 'd' && !isCredits(courseListItem[j])) {
if (isFinalScore(courseListItem, j)) {
item.finalScore = courseListItem[j].trimStart()
item.isPass = isPass(courseListItem[j])
}else if (isCredits(courseListItem[j-1])) {
item.performanceScore = courseListItem[j].trimStart()
}else {
if (courseListItem[j] === '是') {
item.isRenovate = courseListItem[j] === '是'
}else if (courseListItem[j].match(/(学院|学部)/)) {
item.college = courseListItem[j].trimStart()
}else {
assessmentScore.push(courseListItem[j].trimStart())
}
}
}
}
item.assessmentScore = assessmentScore
resultList.push(item)
}
return resultList
}
/**
* 创建表格
*
* @param {Array} list
* @return {String} 文本类型的HTML
* @author ChiyukiRuon
* */
function createTableValue(list) {
var tableText = ''
for (var i = 0;i < list.length;i++) {
var assessmentScore = ''
for(var j = 0;j < list[i].assessmentScore.length;j++) {
assessmentScore += `${list[i].assessmentScore[j]} `
}
if (list[i].isPass) {
tableText += `<tr class="main-table" style="color: rgb(96, 98, 102); height: 40px"><td style="font-weight: bold;"><div class="table-text">${list[i].courseName}</div></td><td style="color: rgb(126, 192, 80)"><div class="table-text">${list[i].finalScore}</div></td><td><div class="table-text">${list[i].performanceScore}</div></td><td><div class="table-text">${assessmentScore}</div></td><td><div class="table-text">${list[i].credits}</div></td><td><div class="table-text">${list[i].college}</div></td></tr>`
}else {
tableText += `<tr class="main-table" style="color: rgb(96, 98, 102); height: 40px"><td style="font-weight: bold;"><div class="table-text">${list[i].courseName}</div></td><td style="color: rgb(228, 116, 112)"><div class="table-text">${list[i].finalScore}</div></td><td><div class="table-text">${list[i].performanceScore}</div></td><td><div class="table-text">${assessmentScore}</div></td><td><div class="table-text">${list[i].credits}</div></td><td><div class="table-text">${list[i].college}</div></td></tr>`
}
}
return tableText.replace(/undefined/g, ' ')
}
var normalString = base64ToString(document.getElementById('__VIEWSTATE').value)
var resultList = siftString(normalString)
var targetElement = document.querySelector('#tbXsxx')
if (targetElement) {
var newElement = document.createElement('div')
newElement.innerHTML = `<table style="width: 100%; font-size: medium; text-align: left;"><tr style="color: rgb(145, 147, 152); height: 40px"><th><div class="table-text">科目</div></th><th><div class="table-text">最终成绩</div></th><th><div class="table-text">平时成绩</div></th><th><div class="table-text">考核成绩</div></th><th><div class="table-text">学分</div></th><th><div class="table-text">开课学院</div></th></tr>${createTableValue(resultList)}</table>`
newElement.style.width = '100%'
targetElement.parentNode.insertBefore(newElement, targetElement)
}
})();