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

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

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

最近构思实现了一个小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': '/'
        }
      }
    }
  }
})

相关推荐

32位office2010下载(32位office2013)
32位office2010下载(32位office2013)

1、先下载office2010完整安装包免费版。2、最开始安装的时候,需要借助一款微软专用清理工具:msiclear。下载软件后双击msicuu2.exe运行软件。3、运行msicuu2.exe后发现桌面没有快捷方式,在窗口-所有程序中...

2025-12-27 00:05 liuian

台式电脑如何设置定时关机时间

设置电脑指定时间自动关机的方法有两种:方法一:点击电脑屏幕左下角的【开始】按钮,并搜索【计划任务】。点击进入【计划任务】页面中,并选择【创建基本任务】。在创建基本任务的页面中输入【名称】和【描述】,点...

台式键盘fn键在哪里(键盘上找不到fn键)

错误。原因是大部分台式电脑的键盘上都有fn键,虽然fn键通常不像笔记本电脑一样与其他按键组合使用,但它可以单独使用来调节音量、屏幕亮度等功能。fn键起源于笔记本电脑,它的功能键组合可以帮助使用者快速地...

fast无线路由器设置步骤图解
  • fast无线路由器设置步骤图解
  • fast无线路由器设置步骤图解
  • fast无线路由器设置步骤图解
  • fast无线路由器设置步骤图解
怎么用手机控制家里的wifi(怎么用手机控制家里的wifi不让孩子看电视)

以华为手机P40,EMUI10系统为例,如果想要用手机控制wifi的连接设备,就需要先拥有WiFi设备的管理员密码,用手机控制wifi的连接设备有下列几个步骤:1、需要使用手机下载路由器对应的app,...

外接移动硬盘在电脑上不显示怎么办

答:外接硬盘不显示在我的电脑,这种情况一般是因为USB供电不足导致的,如将移动硬盘用USB连接线连接电脑机箱前置面板,将移动硬盘USB线2个USB插头都插上前面板的USB接口。如果是接机箱后主板USB...

bootice修复win10(bootice修复uefi引导)

制作个PE,然后进入PE修复引导即可,具体操作方法:1、首先准备一个制作好的U盘装机大师U盘启动盘,然后连接好电脑与U盘启动盘。重启电脑,在开机画面出现时按下启动快捷键,选择U盘启动,然后就进入了U盘...

手机自带软件怎么卸载(vivo手机自带软件怎么卸载)

答:卸载手机自带应用的方法步骤如下:1.通过应用程序管理器卸载:转到手机的设置菜单,然后找到并点击“应用”或“应用程序管理器”等选项(依据不同品牌和型号手机可能略有差异)。在应用程序列表中,浏览并找...

微信可以设置主题皮肤吗(微信可以设置主题嘛)
  • 微信可以设置主题皮肤吗(微信可以设置主题嘛)
  • 微信可以设置主题皮肤吗(微信可以设置主题嘛)
  • 微信可以设置主题皮肤吗(微信可以设置主题嘛)
  • 微信可以设置主题皮肤吗(微信可以设置主题嘛)
3dmax电脑配置要求(3dmax电脑配置要求i5还是i7)

以下是3dsMax2021的最低系统要求:-操作系统:Windows10(64位)-处理器:64位Intel或AMD多核处理器-内存:至少需要16GBRAM,建议32GBRAM-...

声卡驱动需要更新吗(声卡驱动更新好还是不更好)

  如果声卡使用正常,就不建议无谓地更新驱动。只有在声卡工作异常时,才首先进行驱动的更新。  驱动程序的更新,很多时候是为了支持更多新发布的产品,或者修复已知的问题。当硬件本身工作正常的时候,其实没有...

windows10系统怎么更新(win10系统更新怎么更新)

要升级Windows10系统版本,首先确保你的计算机连接到互联网。然后,点击开始菜单,选择“设置”选项。在设置窗口中,点击“更新和安全”选项。在更新和安全窗口中,点击“Windows更新”选项。系...

win7如何用光盘重装系统(如何用光盘重装系统win7旗舰版)
  • win7如何用光盘重装系统(如何用光盘重装系统win7旗舰版)
  • win7如何用光盘重装系统(如何用光盘重装系统win7旗舰版)
  • win7如何用光盘重装系统(如何用光盘重装系统win7旗舰版)
  • win7如何用光盘重装系统(如何用光盘重装系统win7旗舰版)
win7用360升级win10(如何用360更新windows7)

360系统重装大师可以升级win10,但具体要看你原来电脑系统的系统分区和硬盘分区是否满足WIN10的需要,WIN10系统最少要求硬盘C盘保留20G空间,内存需要4G以上,如果你的电脑硬件配置不够满足...

电脑无线鼠标没反应怎么办(电脑无线鼠标不起作用怎么办)

电脑无线鼠标不动了,解决方法:1、确认鼠标上的开关是否打开。如果没打开,请打开开关按钮。2、确认鼠标里的电池是否有电。如果电池没电,请更换新的电池。3、确认接收器是否连接好,如果已接好,尝试请更换另一...