开发定制:学校考试成绩自动处理,可定制规则

news/2024/9/19 18:51:35 标签: python

 需求分析:
教导处在年中或年尾时要对成绩,按一定规则分析处理。都是些重复性工作。所以有必要自动处理。

广告:按规则定制自动处理软件或网页设计。

以下技术栈和步骤:

  1. 后端 (Flask): Flask 是一个轻量级的 Python Web 框架,适合处理上传文件、数据处理等任务。我们可以利用它处理本地文件,并返回处理结果。

  2. 前端 (HTML + JavaScript): 用 HTML 创建一个简单的网页,提供按钮用于上传文件,以及展示表格的地方。可以用 JavaScript 实现文件上传后的动态表格生成和滚动条。

  3. 数据处理 (Pandas): 使用 pandas 来处理上传的 Excel 文件,读取文件中的表格,根据年级和班级计算学科的平均分。

  4. 文件导出 (XlsxWriter): 在前端提供一个“导出”按钮,将计算后的结果导出为自定义的 Excel 文件。

 

代码实现:

1. 安装必要的库:
pip install flask pandas xlsxwriter

2. 创建 Flask 后端

from flask import Flask, render_template, request, jsonify, send_file
import pandas as pd
import os

app = Flask(__name__)

@app.route('/')
def index():
    return render_template('index.html')

@app.route('/upload', methods=['POST'])
def upload_file():
    file = request.files['file']
    df = pd.read_excel(file)
    
    # 计算年级+班级的平均分
    avg_df = df.groupby(['年级', '班级']).mean().reset_index()

    # 将平均分转换为 JSON 格式返回前端
    return jsonify(avg_df.to_dict(orient='records'))

@app.route('/export', methods=['POST'])
def export_file():
    data = request.json['data']
    df = pd.DataFrame(data)
    
    # 保存为自定义的 Excel 文件
    output_path = 'exported_data.xlsx'
    df.to_excel(output_path, index=False)
    
    # 发送文件到前端供下载
    return send_file(output_path, as_attachment=True)

if __name__ == '__main__':
    app.run(debug=True)

 

 3. 创建前端模板 templates/index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Excel Processor</title>
    <style>
        table {
            width: 100%;
            border-collapse: collapse;
        }
        th, td {
            padding: 8px;
            text-align: left;
            border: 1px solid black;
        }
        #table-container {
            max-height: 400px;
            overflow-y: scroll;
        }
    </style>
</head>
<body>
    <h1>上传文件并计算平均分</h1>
    <input type="file" id="fileInput">
    <button onclick="uploadFile()">打开本地xlsx文件</button>
    <button onclick="exportData()">导出数据</button>

    <div id="table-container">
        <table id="dataTable">
            <thead>
                <tr>
                    <th>年级</th>
                    <th>班级</th>
                    <th>语文</th>
                    <th>数学</th>
                    <th>英语</th>
                </tr>
            </thead>
            <tbody>
            </tbody>
        </table>
    </div>

    <script>
        let tableData = [];

        function uploadFile() {
            const fileInput = document.getElementById('fileInput');
            const file = fileInput.files[0];
            
            if (file) {
                const formData = new FormData();
                formData.append('file', file);

                fetch('/upload', {
                    method: 'POST',
                    body: formData
                })
                .then(response => response.json())
                .then(data => {
                    tableData = data;
                    populateTable(data);
                });
            }
        }

        function populateTable(data) {
            const tbody = document.getElementById('dataTable').querySelector('tbody');
            tbody.innerHTML = '';  // 清空之前的表格数据

            data.forEach(row => {
                const tr = document.createElement('tr');
                tr.innerHTML = `
                    <td>${row['年级']}</td>
                    <td>${row['班级']}</td>
                    <td>${row['语文'] ? row['语文'].toFixed(2) : ''}</td>
                    <td>${row['数学'] ? row['数学'].toFixed(2) : ''}</td>
                    <td>${row['英语'] ? row['英语'].toFixed(2) : ''}</td>
                `;
                tbody.appendChild(tr);
            });
        }

        function exportData() {
            fetch('/export', {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json'
                },
                body: JSON.stringify({ data: tableData })
            })
            .then(response => response.blob())
            .then(blob => {
                const url = window.URL.createObjectURL(new Blob([blob]));
                const link = document.createElement('a');
                link.href = url;
                link.setAttribute('download', 'exported_data.xlsx');
                document.body.appendChild(link);
                link.click();
                link.parentNode.removeChild(link);
            });
        }
    </script>
</body>
</html>

 

功能:

  1. 文件上传:用户点击按钮选择本地的 xlsx 文件。
  2. 平均分计算:Flask 后端处理文件并计算年级和班级的平均分,返回前端显示。
  3. 表格展示:前端动态生成表格,显示计算出的平均分,并根据行数自动出现滚动条。
  4. 数据导出:用户可以点击“导出数据”按钮,将处理后的数据导出为 Excel 文件。


http://www.niftyadmin.cn/n/5665985.html

相关文章

监控易监测对象及指标之:全面监控ElasticSearch集群

随着大数据和云计算技术的不断发展&#xff0c;ElasticSearch作为一款基于Lucene的开源搜索引擎&#xff0c;已成为众多企业和组织进行全文搜索、结构化搜索和分析的首选工具。然而&#xff0c;随着ElasticSearch集群规模的不断扩大&#xff0c;如何有效监控其运行状态、确保服…

vue3+ant design vue 中弹窗自定义按钮设置及以冒号为基准布局

1、自定义弹窗按钮&#xff0c;去除取消和确定按钮。&#xff08;网上很多方法都是说通过插槽来实现&#xff0c;但是试了下不生效&#xff0c;那既然插槽不生效的话&#xff0c;干脆直接写按钮就好了&#xff09; <a-modalv-model:open"open"title"人员信息…

运营社媒账号为什么需要使用静态IP

在现代社交媒体管理中&#xff0c;运营一个或多个社交媒体账号已经成为许多企业和个人的常态。为了确保高效、安全的管理&#xff0c;这些用户往往会考虑使用静态IP地址。虽然动态IP地址对大多数日常网络活动来说已足够&#xff0c;但静态IP在社交媒体运营中提供了许多不可忽视…

【VitualBox】VitualBox的网络模式+网络配置

VirtualBox 1. 简介 VirtualBox 是一款开源虚拟机软件&#xff0c;使用者可以在VirtualBox上安装并且执行Solaris、Windows、DOS、Linux、OS/2 Warp、BSD等系统作为客户端操作系统。 2. 六种网络接入模式 VirtualBox提供了多种网络接入模式&#xff0c;他们各有优缺点&#xf…

BitLocker硬盘加密的详细教程分享

硬盘加密是将数据转换为一种只有授权用户才能读取的形式。通过使用加密算法&#xff0c;硬盘上的数据在存储时被加密&#xff0c;只有输入正确的密钥或密码才能解密和访问这些数据。 硬盘加密的重要性 数据是现代社会的重要资产&#xff0c;保护这些数据免受非法访问和窃取至关…

第九章,网络编程

高级编程 文章目录 高级编程第九章&#xff0c;网络编程一&#xff0c;概述二&#xff0c;IP地址三&#xff0c;网络通信四&#xff0c;Socket简介 第九章&#xff0c;网络编程 一&#xff0c;概述 计算机网络&#xff1a;计算机网络是指将地理位置不同的具有独立功能的多台计…

pdf怎么合并成一个文件?6种方法教你快速合并

在日常工作或学习中&#xff0c;我们经常需要将多个PDF文件合并成一个文件&#xff0c;以便于管理和分享。今天&#xff0c;就为大家介绍6种高效的PDF合并方法&#xff0c;包括专业操作工具和在线合并网站&#xff0c;适合各个层次的人群使用&#xff0c;快来一起学习下吧。 方…

uni-app生命周期(三)

文章目录 一、uni-app的生命周期二、应用生命周期三、页面的生命周期函数1.简介2.页面加载时序介绍3.页面加载常见问题4.页面加载顺序4.部分生命周期介绍 四、组件的生命周期函数 一、uni-app的生命周期 应用生命周期&#xff08;整个App的生命周期&#xff09; 在app.vue里面…