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

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

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

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

相关推荐

怎么查看宽带账号和密码(怎么查宽带帐号和密码)
怎么查看宽带账号和密码(怎么查宽带帐号和密码)

宽带账号密码要记牢,重要的账号密码要记小本本上!下面我来具体讲讲获取方法。1.查看发票、合同、官方小卡片是否标明。以我们这个城市为例,发票上的用户号码就是宽带账号。047403100006就是宽带账号,密码是123456,密码错误就是身份证...

2025-12-19 21:05 liuian

预装系统的固态硬盘怎么安装

首先,安装系统有三个办法可以选择:一是在固态硬盘上全新安装系统;二是在PE系统下,将机械硬盘上的系统克隆到固态硬盘上。注意GPT格式的硬盘不能用这个方法。三是HDD安装。然后,主板设置中将固态硬盘设置...

如何还原已经被删除的文件(如何还原彻底删除的文件)

首先我们需要通过浏览器搜索互盾数据恢复软件,将这款软件下载到我们的电脑上1、下载好后运行互盾数据恢复软件,软件界面有六大功能,因为我们需要对回收站清空的数据进行恢复,所以点击界面的“误清空回收站”即...

mhdd硬盘修复教程(如何用mhdd修复硬盘)

eraser这个选项试试。mhdd修复效果不是很好哦打开MHDD的重映射功能,就是REMAP选为NO,然后再重新扫描就可以自动映射了1在DOS下运行MHDD,软件启动后按F4;2点一下上方向键,再...

手机真伪查询官网入口(荣耀手机真伪查询官网入口)

进入http://www.tenaa.com.cn/网站后,首先输入的是您的省份,城市,和许可证号.许可证号需要去掉电池,在手机的后面看一个贴条:进网许可;第一行就是许可证号;第二行是设备型号;第三行...

穿越诸天万界推倒女主角的小说

《绝代双骄》。对于此书,其深入人心有目共睹,我就不再赘述了。据我所知,包括歌仔戏在内它的版本至少有七种,不过最好的梁吴版都没能演出其精髓。此书或许可以看作承前启后的作品:既为之前的传统套路作了个精彩的...

电脑grub怎么修复系统(windows grub修复)

方法是:1、准备一个任意大小的u盘,然后在能正常使用的电脑搜索通用pe工具箱,在官网下载最新的通用pe工具箱。安装它,然后将u盘制作成u盘启动盘。2、接着我们将制作好的u盘启动盘,插在报错的电脑上,重...

photoshop安卓手机版下载(photoshop android版)

1.在搜索引擎中输入adobe并点击搜索。2.点击adobe官网。3.点击支持并点击下载与安装。4.点击开始免费试用并点击下载。5.打开文件夹并点击打开进行安装即可。点击开始免费试用并点击下载。5.打...

笔记本无线上网卡包月(笔记本无线上网卡包月多少钱)

您好,各地区无线包月上网卡资费情况是不同的,建议以您当地电信资费为准,湖北电信的包月无线上网卡:1、天翼宽带上网卡省内流量套餐(8G),2、【4G上网卡】天翼宽带上网卡省内流量套餐(20G),更多上网...

正版计算器下载(下载计算器普通版)
正版计算器下载(下载计算器普通版)

1.检查应用程序中的各文件夹,查看计算器图标是否整理到某文件夹中。2.部分手机支持隐藏应用程序功能,取消隐藏后查找。3.查看是否禁用计算器功能,取消禁用尝试。操作:进入设定-(应用程序)-应用程序管理器中查找计算器图标,选择启用。4.部分手...

2025-12-19 16:55 liuian

win10永久激活密钥大全(win10正版永久激活密钥)

1不是免费的2Win10永久激活密钥并不是免费的,因为微软公司对于正版软件的授权是需要收费的。通过购买正版授权密钥,用户可以合法地激活Windows10操作系统,享受到正版软件的各种功能和更新支...

笔记本点关机键无反应(笔记本电脑点关机键没反应怎么回事)

解决方法:1、右键点击【计算机】图标2、点击【管理】选项?3、点击【设备管理器】选项4、右键点击【图像设备】?5、点击【禁用】6、再次点击【关机】按钮即可完成关机。1、拔掉外设启动电脑试试,重新拔插一...

电脑死机画面卡住不动是什么原因

一、软件问题  有时我们的电脑频繁死机有可能是某些软件点用了大量的电脑资源,还有一种情况是电脑中毒了,有些病毒会占掉大量的内存,从而让你的电脑频繁死机或频繁重启,你可以查看一下任务管理器中的性能,看看...

办公用台式电脑什么配置比较好

办公用的电脑的配置要求: 1、办公电脑硬盘要求很多人在配置办公电脑的时候习惯性的只配一块比较大的HDD硬盘,其实没必要,不过实际上如果不是大规模的绘图制作的话,一块小巧的SSD完全就可以...

win10系统的条件(win10系统需要什么条件)

Windows10安装要求:1、处理器:1千兆赫(GHz)或更快;2、内存:1GB(32位)或2GB(64位)以上;3、可用硬盘空间:16GB以上;4、图形卡:带有WDDM驱动程序的Microsoft...