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

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

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

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

相关推荐

固态硬盘什么牌子好用(固态硬盘那种牌子好)

讨论极端耐用的,企业级Intels3710系列SSD。intel自家产mlc闪存颗粒及盘控芯片,各项性能顶尖,盘控优秀,支持每天硬盘满容量数据的10次擦写,连续5年……基本用不坏的,你说耐用不耐用?...

win7主题重启就改变(win7主题重启就改变了吗)

这种情况很正常,安全模式下杀毒的话,杀毒软件有可能是检测到系统保护文件被修改(就是说你的主题文件被病毒或木马修改了),杀毒软件对修改过的系统保护文件,会修复它,使其恢复到系统最初的原样,(也就是将主题...

ubuntu安装显卡驱动(ubuntu安装显卡驱动后黑屏)

Ubuntu是一种流行的Linux操作系统,其显卡驱动的安装方法如下:1. 检查显卡型号:在Ubuntu系统中,打开终端(Terminal),输入lspci-k命令,查看显卡...

手机退出返回键怎么设置(ⅴiv0手机返回键怎么设置)

手机退回调出来办法如下:首先打开手机,然后点击设置,之后点击系统,然后点击系统导航,接着点击导航栏后面的设置,将导航栏可隐藏的开关向左滑动,然后返回手机桌面,会发现手机桌面下方已经显示返回键。1、手机...

系统安装教程win10如何激活(装系统怎么激活 w10)

方法一:1.查看方法"WIN+R"打开运行对话框,输入命令slmgr.vbs-xpr,点击确定,这样可以查看到当前系统的激活信息。2.在Windows10专业版测试成功,我们可以在此...

塞班系统软件(塞班系统软件安装包)

我觉得这个问题不大,只要我们常用的手机软件还支持塞班,我们就应该还能用。诺基亚今天宣布终结塞班,是指不对塞班系统进行更新了,就像winows宣布不对XP系统进行更新补丁是一样的。苹果的软件商店系统...

华为笔记本电脑价格大全(华为电脑笔记本价格大全5999)

华为MateBookD比较适合玩游戏,是一款出色的大视野影音笔记本,15.6英寸显示屏,分辨率高达1920X1080,画面细腻,色彩真实。显示屏、显卡、音效、处理器,全面满足娱乐、游戏使用。杜比全景声...

联想台式电脑u盘重装系统步骤图解

步骤一:准备U盘首先需要准备一个容量不小于8GB的U盘,并保证其无需重要数据,因为制作系统盘会将U盘内所有数据清空。步骤二:下载操作系统镜像文件接着需要下载指定版本的操作系统镜像文件,可在官网或其他下...

下载吧音乐官网(下载吧音乐app)

可以,下歌吧app是一款专为爱好K歌人士定制的移动手机应用,一个可以把手机变成电视机遥控器的神器应用。下歌吧可以为电视用户提供卡拉OK服务,该款产品能够完成点歌控制和歌曲播放的完整工作。通过手机和电视...

有必要买高配置电脑吗(高配置电脑的好处)

电脑的高配和低配除游戏时的区别外还表现在:1、功耗方面,高配置的电脑往往功耗较大。2、高输出制作软件时,高配置的显卡往往能较快输出。3、效率,高配电脑无论是影音还是浏览网页,一般都是比较流畅的。4、配...

window7下载安卓版(安装版win7下载)

Win7电脑系统下载。可以在MSdn上面去进行下载操作。下载完操作系统以后,然后通过U盘引导的方式去安装电脑。注意C盘必须保留100级到150级左右的空间。然后多余的容量可以给到你的D盘去使用,用来...

win7高级模式怎么还原系统(win7的高级系统设置在哪)

windows7电脑恢复出厂设置方法一  按下开机键,启动计算机;  按F8,进入Windows7的高级启动选项;  选择“修复计算机”。  如果有管理员密码,需要输入;如果没有设置密码,直接“确定”...

银行系统维护需要多久(银行系统维护需要多久才能恢复)

1~2个工作日不等。银行需要进行系统维护时,一般会提前贴示维护公告,告知客户银行系统维护期间的一些暂停办理的相关业务以及可办理业务。银行系统维护期间会暂停的业务主要有:个人网银、手机银行、微信银行、电...

重装nvidia显卡驱动(怎样重装nvidia驱动程序)
  • 重装nvidia显卡驱动(怎样重装nvidia驱动程序)
  • 重装nvidia显卡驱动(怎样重装nvidia驱动程序)
  • 重装nvidia显卡驱动(怎样重装nvidia驱动程序)
  • 重装nvidia显卡驱动(怎样重装nvidia驱动程序)
百度云盘网页版登录入口(百度云网页版登录网站)

有您好,如果百度网盘TV不显示APK,可以尝试以下解决办法:1.重新登录账号:退出百度网盘TV账号,重新登录账号,刷新页面,看看能否显示APK。2.清除缓存:在手机设置中找到百度网盘TV应用,进入应用...