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

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

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

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

相关推荐

下面关于windows7的主题(以下关于windows7的说法错误的是)

只求能帮到楼主Windows7主题创建与修改技巧大全Windows7主题是计算机上的图片、颜色和声音的组合。它包括桌面背景、屏幕保护程序、窗口边框颜色和声音方案。某些主题也可能包括桌面图...

win7开启guest账户(电脑开启guest)

GUEST账户是来宾账户,系统自带的,无法删除,只能禁用,因为有些系统服务需要用到他,按照你的说法已经禁用如果禁用不了,就在开机按F8,进入安全模式,不要进GUEST账号,进其他的账号再禁用账号。第...

成都电脑培训班零基础(成都口碑最好的电脑培训学校)

成都新阳培训学校是经国家人社部批准成立的正规电脑培训学校,由多家广告公司及计算机企业共同承办,是成都较早的计算机培训学校,属全国IT认证培训机构。学校1999年成立,具有专业的师资力量,在办学近二十年...

打印机共享网络发现打不开(打印机网络共享连上不能打印)

打印机共享后还是无法连接网络可通过以下步骤进行排障解决:1、选择需要连接的打印机,右击选择打印机属性,选择共享选项,在共享前面打勾,确认此打印机已可共享给其它电脑,点击确定;2、在电脑中进入“网络”,...

刻录光盘操作方法(nero刻录光盘操作方法)

刻录光盘的具体步骤如下:1.准备刻录软件:选择一款适合自己的刻录软件,比如Nero、ImgBurn等,并安装好。2.准备光盘:选择一张空白的可刻录光盘(CD-R、DVD-R或BD-R),并确保其...

windows+media+player服务器运行失败

WindowsMediaPlayer播放文件时出现问题,可能由以下原因导致:1、WindowsMediaPlayer软件问题;2、播放文件问题(如音乐、视频等)。解决办法:...

在外置移动硬盘中安装win10(在外置移动硬盘中安装win10怎么安装)

1、win10下,进入控制面板-管理工具-计算机管理-磁盘管理,在usb移动硬盘的分区上点鼠标右键,点“将分区标记为活动分区”。2、将windows10安装盘(或者iso文件直接解压,或用虚拟光驱加载...

电脑放歌怎么没有声音(电脑没声音按三个键恢复)

方法一:检查电脑的声音程序,依次点击开始、控制面板、硬件和声音、声音,在声音界面右键并启用已停用的扬声器选项即可。方法二:点击开始搜索栏搜索设备管理器,在界面中点击声音、视频和游戏控制器,右键Real...

电脑桌面手机版下载免费(电脑桌面手机版下载免费软件)
  • 电脑桌面手机版下载免费(电脑桌面手机版下载免费软件)
  • 电脑桌面手机版下载免费(电脑桌面手机版下载免费软件)
  • 电脑桌面手机版下载免费(电脑桌面手机版下载免费软件)
  • 电脑桌面手机版下载免费(电脑桌面手机版下载免费软件)
电子邮件怎么写(苹果平板注册新id 时电子邮件怎么写)

电子邮箱格式:电子邮箱具有单独的网络域名,其书写格式也有一定的要求。一般来说,电子邮箱的格式是:用户名@域名。我们常用的几种电子邮箱的格式如下:1、QQ邮箱:QQ号(数字)@qq.com。2、1...

怎么登录qq邮箱在手机上(如何登入手机qq邮箱)

具体操作如下:1、登录手机QQ;2、在手机QQ主菜单中选择下方的“联系人”选项卡;3、在“联系人”中选取“公众号”选项卡;4、在公众号中菜单中找到或搜索“QQ邮箱提醒”,点击进入;5、点击“进入邮箱”...

wifi出现感叹号怎么解决(wifi出现感叹号是什么故障)

步骤一  首先,出现无线网络出现黄色感叹号,不要着急砸电脑,砸路由器。先用win7自带的网络诊断疑难解答,解决下看出现怎么状况了,可以先右击无线网络。  步骤二  提出的问题,用自带的解决办法解决不了...

如何下载360软件管家(360下载助手)

你好你可以用上面的浏览器登录360平板卫士官网下载安装最新的平板卫士就可以了。360软件管家让软件默认安装在D盘在设置好默认路径即可。方法步骤如下:2、点击右上角的菜单展开按钮,选择“设置”。3、在软...

win10 ie图标删不掉(电脑桌面上的ie图标删不掉)

因为IE浏览器是我们电脑系统自带的浏览器,所以要将其删除就要在电脑系统的注册表中进行系统删除才行。下面给大家讲解一下删除IE浏览器的正确步骤。首先我们要在电脑系统开始菜单中运行regedit后打开电脑...

雨林一键重装系统(雨林系统安装)

电脑系统安装步骤:1、用【u启动u盘启动盘制作工具】制作u启动盘,重启电脑等待出现开机画面按下启动快捷键,选择u盘启动进入到u启动主菜单,选取“【02】Win8PE装机维护版(新机器)”选项2、进入w...