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

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

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

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

相关推荐

vivo手机驱动下载(vivo 驱动)

Vivo手机驱动是一种软件程序,用于连接计算机与Vivo手机之间的通讯,使得计算机可以识别和与Vivo手机进行数据传输。驱动程序会将计算机所需的信息转换为Vivo手机可以理解的形式,然后将数据传输到手...

xp快速启动(winxp系统如何设置快速启动)

1打开电脑脑的外部设备的电源开关,如显示器,音箱,打印机等,再接一下主机上的电源按钮2电脑显示开机自检画面,一般会显示主板信息,内存,显存等的大小信息,还有可以进行主板设置。3进入XP的启动画面和欢迎...

win10桌面卡死无响应(win10桌面一直卡死)

一、重启Windows资源管理器。1、首先看一下键盘能不能用,按下win+D显示桌面快捷键尝试解除假死现象。2、如果不行就按下Ctrl+Alt+Del快捷键,弹出窗口中选择任务管理器。3、找到并选中W...

u盘显示一下就消失了(u盘过一会就没有了)

u盘插入显示了一下就消失可能是设置了隐藏的驱动器处理方法:取消勾选“隐藏的驱动器”,具体步骤:1、首先要排除是不是U盘损坏的问题,当U盘插入到其他电脑,如果可以读出来,那么肯定不是U盘的问题了。2、很...

组装台式电脑配置(组装台式电脑配置清单2019)

2022年台式电脑建议你可以配16gb或32gb的内存。硬盘呢可以配1tb或者是2tb的硬盘。因为电脑的硬件是不断的升级换代的,我推荐你的配置,起码能确保大概3~5年之内不会落伍。方面于办公和生活,并...

笔记本电脑十大品牌排行榜前十名

笔记本电脑品牌排名前十通常包括以下品牌: 1.惠普(HP):惠普是全球最大的计算机制造商之一,其产品线广泛,从入门级到高端商务笔记本都有覆盖。 2.联想(Lenovo):联想也是全...

登录qq恢复官方网站(qq恢复官方网站免费)
登录qq恢复官方网站(qq恢复官方网站免费)

qq恢复官方网站,http://huifu.qq.com/1、什么是QQ恢复系统?QQ恢复系统是腾讯公司提供的一项找回QQ联系人、QQ群的服务,向所有QQ用户免费开放。2、QQ恢复系统能恢复多长时间内删除的好友?普通用户可以申请恢复3个月内...

2026-01-21 23:21 liuian

笔记本风扇声音大正常吗(笔记本风扇噪音大是坏了吗)

1、天气过热,机箱内部持续高温,无法及时散热,导致散热风扇持续高速运转,导致噪音变大。解决方案:应将机器在较为阴凉的室内使用或者开启室内空调来控制室温,以防止室内温度过热对电脑造成影响。若使用的是笔记...

wlan下载安装(手机wlan下载安装)

如果是电脑新加了无线网卡的话最简单的办法就是下载一个超级兔子,或是驱动精灵,检测一下硬件,让它自动为你安装驱动,如果是手机的话,那就免了,因为这和电脑的一样,同样是硬件,但自己是加不了的不连接路由器...

autocad2010免费下载(cad2010官方下载地址)

PowerPoint2010是MicrosoftOffice套件中的应用程序,您可以通过以下步骤在计算机上安装PowerPoint2010:1.确认您的计算机的操作系统是否符合要求。Power...

u盘访问被拒绝如何获取权限(u盘文件访问被拒绝是什么意思)

如果您的U盘没有权限访问,可以尝试以下方法:1.以管理员身份运行文件资源管理器:右键单击“开始”菜单,选择“文件资源管理器”,然后右键单击文件资源管理器的图标,选择“以管理员身份运行”选项。2.更...

qq注册靓号免费申请网址(qq申请靓号免费注册官网)
qq注册靓号免费申请网址(qq申请靓号免费注册官网)

1、点击手机桌面上的QQ,点击用户注册;填写手机号,点击下一步,填写收到的验证码;如此手机号已被他人注册可点击继续注册,点击绑定新QQ号;填写昵称和密码,填写完成后点击登录,通过验证就申请成功了。2、QQ靓号是腾讯公司推出的一种增值QQ号码...

2026-01-21 22:05 liuian

win7cmd关机命令(windowcmd关机)

选择“开始→运行”:1、输入“at22:00Shutdown-s”,这样,到了22点电脑就会出现“系统关机”对话框,默认有30秒钟的倒计时并提示你保存工作。2、输入“Shutdown.exe...

window7下载window8(window7下载一键重装如何恢复网络)

在网页找到安装包,下载,解压并安装即可小米目前还没宣布使用鸿蒙系统,所以目前还不能下载鸿蒙系统。您好,简单换算的话,您的网速就是8MB*8=64M宽带,这种网速在现在而言只能算是一般了要下载云顶游戏,...

flash插件手机版下载官网(flash插件下载手机版下载安装)
flash插件手机版下载官网(flash插件下载手机版下载安装)

AdobeFlashPlayer是Android系统的一项重要功能,这款Android软件可以让自己的Android手机访问基于Flash制作的视频、游戏、互动媒体、网络应用程序等网站功能。FlashPlayer将实现一个完整的Web...

2026-01-21 21:21 liuian