百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

fastapi+vue3文件上传(vue formdata上传文件)

liuian 2025-04-06 18:08 112 浏览

最近构思实现了一个小demo网站,前端上传文件,后端分析文件,最后前端展示,整个过程还是蛮有意思的,刚刚开始学习网站开发,还有很多不会的地方,这里演示fastapi+vue3文件上传,上传的excel文件直接存入mongo中,读也是从mongo中读。

后台代码:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2024/1/19 09:20
# @Author  : ailx10
# @File    : main.py

# main.py
from fastapi import FastAPI
from fastapi.middleware.cors import CORSMiddleware
import pandas as pd
from pymongo import MongoClient
import io
from fastapi import File, UploadFile
from fastapi.responses import JSONResponse

app = FastAPI()

# CORS 设置,允许所有来源访问,生产环境时应根据需要进行调整
origins = ["*"]
app.add_middleware(
    CORSMiddleware,
    allow_origins=origins,
    allow_credentials=True,
    allow_methods=["*"],
    allow_headers=["*"],
)


client = MongoClient("mongodb://admin:passwd@localhost:27017/")
db = client.alarm_analysis
collection = db.raw_sample


@app.get("/get_samples/{page}")
async def get_samples(page: int):
    skip = (page - 1) * 10
    samples = collection.find().skip(skip).limit(10)

    # 转换 ObjectId 为字符串
    samples = [{**sample, "_id": str(sample["_id"])} for sample in samples]

    total_samples = collection.count_documents({})  # 获取总样本数

    return JSONResponse(content={"data": samples, "total": total_samples})


@app.post("/upload_excel")
async def upload_excel(file: UploadFile = File(...)):
    contents = await file.read()
    df = pd.read_excel(io.BytesIO(contents))

    samples = df.to_dict(orient="records")
    result = collection.insert_many(samples)

    return {"inserted_ids": [str(id) for id in result.inserted_ids]}

前端代码:

// HelloWorld.vue



<script>
import axios from 'axios';

export default {
  data() {
    return {
      samples: [],
      page: 1,
      totalPage: 1,
    };
  },
  mounted() {
    this.loadSamples();
  },
  computed: {
    filteredKeys() {
      // 获取样本的键,排除 _id 和 sheet
      return Object.keys(this.samples[0] || {}).filter(key => key !== '_id' && key !== 'sheet');
    },
  },
  methods: {
    async uploadExcel(event) {
      const file = event.target.files[0];
      const formData = new FormData();
      formData.append('file', file);

      // 使用代理配置的URL
      await axios.post('/api/upload_excel', formData);

      // 重新加载样本数据
      this.page = 1;
      this.samples = [];
      this.loadSamples();
    },
    async loadSamples() {
      const response = await axios.get(`/api/get_samples/${this.page}`);
      this.samples = response.data.data;

      // 计算总页数,假设每页显示10行
      this.totalPage = Math.ceil(response.data.total / 10);
    },
    validatePage() {
      // 确保输入页码在有效范围内
      if (this.page < 1 this.page='1;' else if this.page> this.totalPage) {
        this.page = this.totalPage;
      }
    },
    prevPage() {
      if (this.page > 1) {
        this.page -= 1;
        this.loadSamples();
      }
    },
    nextPage() {
      if (this.page < this.totalPage) {
        this.page += 1;
        this.loadSamples();
      }
    },
  },
};
</script>

代理配置:

// vue.config.js

const { defineConfig } = require('@vue/cli-service')

module.exports = defineConfig({
  transpileDependencies: true,
  devServer: {
    open:true,        
    host:'localhost',        
    port:8080,        
    https:false,       
    proxy: {
      '/api': {
        target: 'http://localhost:8000',
        changeOrigin: true,
        pathRewrite: {
          '^/api': '/'
        }
      }
    }
  }
})

相关推荐

联想电脑客服中心(联想电脑官方客服电话人工服务)

联想个人及家庭用户购买与服务热线400-990-8888联想商用客户服务热线400-810-6666联想ThinkPad产品服务热线400-100-6000联想ThinkPad产品购买咨询400-89...

荣耀最建议买的三款手机(荣耀什么手机值得入手)

2022年荣耀X手机性价比高。1,荣耀X手机在2022年推出的配置相对较高,搭载了高性能的处理器和大容量的内存,使得手机在运行速度和多任务处理方面表现出色。2,荣耀X手机的摄像头技术也得到了进一步的提...

win7系统光驱安装教程(win7系统光驱安装教程图解)
  • win7系统光驱安装教程(win7系统光驱安装教程图解)
  • win7系统光驱安装教程(win7系统光驱安装教程图解)
  • win7系统光驱安装教程(win7系统光驱安装教程图解)
  • win7系统光驱安装教程(win7系统光驱安装教程图解)
为什么公司禁止用wps(为啥wps不能用了)
为什么公司禁止用wps(为啥wps不能用了)

wps文件不能使用五笔输入法,请查证一下电脑中是否安装五笔输入法,如果电脑中安装五笔输入法,在电脑右下角输入方式处,会有五笔的图标。如果在输入方式处没有五笔输入法的图标显示,那么选择打开电脑中360软件管家,搜索搜狗五笔输入法。然后根据向导...

2026-01-26 13:37 liuian

怎么关闭uac权限(怎么关闭uac权限管理)

说明你不是管理员账户,使用的是来宾账户(实质上),或者是管理员账户,但是没有得到最高授权

recovery模式(recovery模式还有密码怎么办)

华为手机进入Recovery操作如下:1、手机不连接USB数据线,关机状态下,同时按住电源键和音量加键,出现开机画面时松开电源键,3秒后再松开音量加键即可进入Recovery模式。2、进入后,按音量加...

win10 oem是正版吗(oem版win10系统能重装吗)

OEM:是给计算机厂商随着计算机贩卖的,也就是随机版。通常微软的操作作系统有三种版本,这三种版本只是销售对象不一样,使用起来都一样。(a)Retail.(零售版):就是在华彩看到有漂亮包装的那种。可以...

windows98什么梗(windows98属于什么软件)

WINDOWS98是微软公司一的经典操作系统他开创了图形化操作系统的新的纪元现在98系统已经基本上消失了,但作为了一个经典版他有着不可磨灭的贡献现在的XPVISTA这里都是在98的基础上...

罗技驱动官网下载(罗技驱动是哪个软件)

您可以去罗技官方网站下载罗技鼠标的驱动程序。以下是下载驱动程序的步骤:1.打开您的浏览器,并访问罗技官方网站(www.logitech.com)。2.在网站上找到“支持”或“驱动程序”等类似的选项...

windows10启动修复无法修复(win10开机启动修复无法修复)
  • windows10启动修复无法修复(win10开机启动修复无法修复)
  • windows10启动修复无法修复(win10开机启动修复无法修复)
  • windows10启动修复无法修复(win10开机启动修复无法修复)
  • windows10启动修复无法修复(win10开机启动修复无法修复)
硬盘显示0字节如何修复(硬盘变成0字节无法访问)

一种解决方法是使用DiskCleanup工具来清理磁盘上的垃圾文件,释放空间;另外一种方法是使用磁盘管理工具调整磁盘分区大小,以便有更多的空间可供使用;另外,还可以将大文件移动到其他磁盘以释放空间。...

directx11修复工具(directx修复工具官网)

一般是显卡驱动太旧。可尝试进行显卡驱动更新。显卡驱动更新步骤如下:步骤一、桌面右击此电脑步骤二、点击属性步骤三、点击设备管理器步骤四、点击显示适配器步骤五、右击需要更新的显卡步骤六、点击更新驱动程序步...

pc游戏(pc游戏免费网站)

十大耐玩的单机游戏:拳皇、现代战争、古墓丽影、上古卷轴5、大富翁4、三国志、英雄无敌、星际争霸、红警、仙剑奇侠传。拳皇是1994年日本SNK公司旗下在MVS游戏机板上发售的一款著名对战型格斗街...

win8小马激活工具(win8小马激活工具怎么用)

小马哥激活工具1、封装第二阶段(PE部署)在通用调用接口中,2、选择(系统部署后或首次登入前),3、运行程序选(OEM7f7)4、参数是(/a/acer/random/protect)5、添加...

office兼容包2007(office兼容包2016)

2007兼容包仅仅用于在使用Office2003打开2007以后的MSOOXML格式的文档(xlsx/docx等等)如果不再用2003打开高版本的Office文档,那兼容包就没用了。可以卸载。1、O...