基于Flask后端框架的均值填充

Flask可以在Jupyter上运行,首先需要安装这两个库:

python 复制代码
!pip install Flask-CORS
python 复制代码
!pip install Flask

引入依赖:

python 复制代码
from flask import Flask, request, jsonify, send_file
import os
import pandas as pd
import io
from flask import Flask
from flask_cors import CORS, cross_origin

处理跨域问题:

python 复制代码
# 创建 Flask 应用
app = Flask(__name__)
CORS(app, expose_headers=['Content-Disposition'])  # 暴露 Content-Disposition 头
# 允许所有域名访问整个应用
@app.after_request
def after_request(response):
    response.headers.add('Access-Control-Allow-Origin', '*')
    response.headers.add('Access-Control-Allow-Headers', 'Content-Type,Authorization')
    response.headers.add('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE')
    return response

定义上传文件路由:

python 复制代码
# 定义上传文件的路由
@app.route('/upload-csv', methods=['POST'])
def upload_csv():
    file = request.files['file']
    if file:
        # 保存文件到服务器的某个位置
        file.save(os.path.join('uploads', file.filename))
        return jsonify(success=True), 200
    else:
        return jsonify(success=False, message='No file part'), 400

定义均值填充路由:

python 复制代码
@app.route('/process-csv', methods=['POST'])
def process_csv():
    # 获取上传的文件和表单数据
    file = request.files['file']
    column = request.form['column']
    min_value = float(request.form['minValue'])
    max_value = float(request.form['maxValue'])

    # 提取原文件名(不带扩展名)
    original_filename = file.filename.rsplit('.', 1)[0]  # 去掉扩展名

    # 读取 CSV 文件
    df = pd.read_csv(file)

    # 处理数据:将超出范围的值替换为均值
    mean_value = df[column][(df[column] >= min_value) & (df[column] <= max_value)].mean()
    df[column] = df[column].apply(lambda x: mean_value if x < min_value or x > max_value else x)

    # 将处理后的数据保存为 CSV
    output = io.BytesIO()
    df.to_csv(output, index=False)
    output.seek(0)

    # 生成新的文件名:原文件名 + "_processed_MeanFilling.csv"
    new_filename = f"{original_filename}_processed_MeanFilling.csv"

    # 返回文件给前端
    return send_file(output, mimetype='text/csv', as_attachment=True, download_name=new_filename)

运行Flask服务器:

python 复制代码
# 运行 Flask 服务器
if __name__ == '__main__':
    app.run(host='0.0.0.0', port=5000)

Flask 是一个轻量级的 Web 框架,适合快速开发小型应用。默认情况下,Flask 会在 http://localhost:5000 上运行。

相关推荐
chao_7894 分钟前
二分查找篇——寻找旋转排序数组中的最小值【LeetCode】
python·线性代数·算法·leetcode·矩阵
金玉满堂@bj21 分钟前
PyCharm 中 Python 解释器的添加选项及作用
ide·python·pycharm
程序员三藏26 分钟前
如何使用Pytest进行测试?
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest
随心点儿1 小时前
使用python 将多个docx文件合并为一个word
开发语言·python·多个word合并为一个
不学无术の码农1 小时前
《Effective Python》第十三章 测试与调试——使用 Mock 测试具有复杂依赖的代码
开发语言·python
sleepybear11131 小时前
在Ubuntu上从零开始编译并运行Home Assistant源码并集成HACS与小米开源的Ha Xiaomi Home
python·智能家居·小米·home assistant·米家·ha xiaomi home
纪伊路上盛名在1 小时前
(鱼书)深度学习入门1:python入门
人工智能·python·深度学习
夏末蝉未鸣012 小时前
python transformers笔记(TrainingArguments类)
python·自然语言处理·transformer
德育处主任Pro2 小时前
「py数据分析」04如何将 Python 爬取的数据保存为 CSV 文件
数据库·python·数据分析
咸鱼鲸2 小时前
【PyTorch】PyTorch中数据准备工作(AI生成)
人工智能·pytorch·python