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

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

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

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

相关推荐

电脑补丁(电脑补丁怎么卸载)

补丁就是系统的漏洞修复程序,装补丁是为了修复系统的漏洞,可以使用360安全卫士修复补丁,装了之后不是用补丁的,而是系统更流畅。电脑中的补丁是一种用于修复软件、操作系统或硬件驱动程序中存在的漏洞、错误或...

电脑打开网页特别慢(电脑打开网页特别慢怎么办)

1.加载网页太慢2.这可能是由于网络连接不稳定、电脑性能不足或者浏览器缓存问题导致的。网络连接不稳定会导致数据传输速度变慢,电脑性能不足会影响网页的加载速度,而浏览器缓存问题可能导致网页无法正常加...

新冠第四针(新冠第四针疫苗最新消息)

是可以打新冠疫苗的第四针了,因为现在的北京市在二零二三年的二月份开始就可以接种了,有吸入式的疫苗,也有针剂的疫苗可以。12月15日起北京多区开始第四针新冠疫苗接种工作接种时间间隔:接种时需要满足与第一...

win10系统更新的补丁在哪里(win10更新补丁位置)
win10系统更新的补丁在哪里(win10更新补丁位置)

win10选择手动更新补丁方法:1.登录win10系统桌面,点击打开开始菜单–电脑设置。2.在打开的电脑设置窗口中,点击“更新和恢复”进入下一步操作。3.在更新和恢复界面中,点击“Windows更新”开始系统更新操作。1、点击“开始”...

2026-01-16 19:37 liuian

电脑怎样复制粘贴(电脑怎样复制粘贴链接)

使用电脑的时候经常会需要使用到复制粘贴功能,许多用户可能会习惯使用右键来复制粘贴,其实这样有点麻烦,比较简单的就是使用快捷键来操作,但是有部分用户还不知道键盘按什么键复制粘贴,如果你也有一样需求的话,...

电脑一重启打印机驱动就没了

你设置了系统保护系统还原了把他取消就可以了右击“我的电脑”选“属性”,在“性能”标签中,选择“文件系统”,在“疑难解答”标签中将“禁用系统还原”选上。还可以、禁用WindowsXP系统还原功能:1.进...

华硕bios按哪个键(华硕bios操作)
华硕bios按哪个键(华硕bios操作)

1、华硕笔记本默认进入bios快捷键是F2;2、如果系统是win8以及win8.1,需要开机提前按住F2键,因为有快速启动,如果按迟了,就无法进入bios;3、进入了bios后,就可以根据需要对bios进行相关设置,由于主板不同,bios设...

2026-01-16 18:55 liuian

电脑开机密码怎么换(电脑开机密码怎么换新密码)

单机电脑左下角“开始”菜单,然后点击菜单栏里的“控制面板”接着点击“用户账户”—“更改账户”再点击“administrator计算机管理员”点击“更改我的密码”就会出现更改密码的对话框在更改密码对话框...

电脑系统哪个好用电脑不卡(电脑哪个系统好用一些)

一般电脑安装硬件原生支持的原版系统是最稳定的,如果电脑安装非原生支持的系统或GHOST等修改版系统,虽然也可以正常使用,但因为兼容性问题,稳定性并不是很好。另外电脑除了需安装原生支持的原版系统外,还必...

360来电卫士官方下载(360来电卫土)

1、进入360手机卫士之后,点击隐私保护,找到开启来电秀。2、在来电秀界面中你可以直接点击下方的开启我的来电秀或者点击右上角的设置按钮,设置来电秀的相关内容。3、点击开启我的来电秀之后,你需要点击相机...

手机网络设置怎么设置(手机没网络怎么办)

网络设置一般有两种:wifi和移动数据。点开“设置”选项,里面有“移动数据”和“WLAN”两个选项,点击“移动数据”,选择使用哪张电话卡的流量,点击就好了;点击“WLAN”,进去之后选择要连接的无线,...

联想商用服务(联想商用服务电话)

人工智能选联想商用有以下优点:技术研发能力强。联想研究院人工智能实验室在技术研发和产品落地上都做出了重要贡献,以不断的创新与突破,助力联想引领各行各业的智能化变革。覆盖的研究领域广泛。联想人工智能实验...

运行启动项的命令(运行 启动项命令)

查看开机启动项的命令是“msconfig”,具体使用方法如下:1、单击屏幕左下角的“开始”2、在弹出菜单中单击“运行”,也可以按键盘上的WIN+R组合键快速调出“运行”栏3、在“运行”栏输入“msco...

numlock一直亮键盘失灵(numlock亮着但是键盘不能用)

键盘的numlock灯亮按键没有反应一般是系统开启了鼠标键功能引起的。使用键盘左侧的ALT+SHIFT+NUMLOCK关闭鼠标键功能。电脑小键盘灯亮着但是数字还是不能键入的解决方法如下:一、numl...

任何小说都能搜到的软件(任何小说都能搜到的软件安卓)
任何小说都能搜到的软件(任何小说都能搜到的软件安卓)

不能,QQ阅读里的小说绝大部分都是签约的,而且都是正式作者,而作者专区里写的文如果通过审核就可以找到。(我就是QQ阅读的一位作者。。。)先找到我的小说,然后查看浏览记录即可。打开头条,用手指按住频道栏向左滑动,找到小说并点击。可以点击男频,...

2026-01-16 16:55 liuian