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

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

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

最近构思实现了一个小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、打开电脑依次选择“开始”“管理工具”-“WindowsSererB。弹出的窗口中有连个选项,选择“在其他位置存储备份”然后单击“下一步”按钮。在选择“本地驱动器”单击“下一步”按钮。2、在选择...

office产品密钥2016专业增强版

office2016专业增强版更改激活密钥步骤如下:(演示使用WIN10系统,其他Windows版本操作大致相同)1丶打开你的word2016,点击左上角的文件。2丶之后单击左侧账户选项卡,点击右侧箭...

无线路由器登陆地址(无线路由器登录地址)
  • 无线路由器登陆地址(无线路由器登录地址)
  • 无线路由器登陆地址(无线路由器登录地址)
  • 无线路由器登陆地址(无线路由器登录地址)
  • 无线路由器登陆地址(无线路由器登录地址)
斐讯k2是千兆路由器吗(斐讯路由器k2是千兆还是百兆)

因为接口不支持。如果是千兆路由,需要进去设置下最大速度,一般是设置为10M,100,1000M自适应。排除电脑网卡不支持100m以上网络的可能。所以千兆路由器,其实可以分为WAN和LAN口全千兆路由器...

windows7企业版和旗舰版区别

Win7企业版(Enterprise)主要对象是企业用户以及其市场,通过大量授权给有与微软签订软件授权合约的公司,同时有一个大量授权的产品密钥,必须通过其激活。这个版本不会通过零售以及OEM贩卖。...

直播笔记本电脑推荐(虚拟直播笔记本电脑推荐)

联想拯救者r720能直播。它的配置一般都足够强悍,可以进行直播的,一般直播来说都需要用到i7的处理器和8G运存。如果你需要直播游戏的话,那么需要用960m以上的显卡,如果你只是普通的聊天直播的话,那么...

win10恢复密钥字母打不上去(win10恢复密钥无法输入英文)

恢复密钥之所以无法输入字母表现为系统闪退,原因和解决方法如下10、系统存储空间严重不足部分应用需要不停的读写数据从而占用系统存储空间,当系统空间严重不足可能会出现卡顿、闪退甚至是死机的现象。解决方法恢...

xp怎么重装系统win10(xp怎么重新装系统)

将WindowsXP系统升级到Windows10系统需要进行全新安装,而不是直接升级。以下是在XP系统中全新安装Windows10系统的步骤:1.了解硬件要求:确定您的计算机是否符合Windo...

台式电脑如何连接无线(台式计算机如何连接wifi)
台式电脑如何连接无线(台式计算机如何连接wifi)

桌面右下角点击一个无线网络的小图标。点开无线网络图标,就能看到附近的wifi网路,找到自己家,或者知道wifi密码的网络。选中自动连接,然后点击“连接”按钮。然后输入wifi密码,点击“下一步”。连接成功之后,无线网列表上面就会提示“已连接...

2026-01-18 07:05 liuian

文件iso怎么解压(如何解压iso文件到u盘)

  可以用WINRAR来解压WIN7镜像文件。  1、现在的WINRAR版本是支持ISO文件的,可在选项菜单中选择设置,在“综合”选项卡中选中ISO文件类型,并确定。  2、这时ISO文件的图标将变成...

手机剪贴板在哪里打开(手机剪贴板在什么地方打开)
手机剪贴板在哪里打开(手机剪贴板在什么地方打开)

1.以小米10,系统MIUI12.0,自带搜狗输入法为例。进入打字界面,呼出键盘2.点击左上角3.点击剪贴板4.剪贴板内容已展示,最多150条。...

2026-01-18 06:37 liuian

车载以太网两根线(车载以太网两根线的缆的电流范围)

以太网的名称来源于人们在查明光和电磁波的传播原理之前,认为空气中存在介质“ether”(以太)。发展到现在,该通信技术已如其名称一样,融入了几乎所有场所,通过与多种网络设备连接实现了普及。到2013年...

windows10原版安装教程(原版win10系统安装详细步骤)

制作好u大师u盘启动盘制作工具后,进入到u大师的pe系统中,等待智能快速装机自动弹出,然后选择在我们u盘的win10系统镜像,这时请选择映像名位置会有三个选项:  k:\sources、install...

如何关闭迈克菲杀毒软件(如何关闭迈克菲杀毒软件功能)

1关闭迈克菲杀毒可以通过以下步骤进行操作。2首先,找到迈克菲杀毒的图标,右键单击打开菜单,选择“退出”选项。3如果上述方法不能关闭杀毒软件,可以尝试在任务管理器中结束迈克菲杀毒的进程。4需要注...

设备遇到问题需要重启和蓝屏

出现蓝屏情况下可以尝试以下几个步骤来重新启动电脑:1.按下电脑主机的开关键并保持5秒钟左右,直到电脑彻底关闭。2.等待几秒钟后,按下电脑电源键打开电脑。如果显示器未正常工作,请检查电源和显示器...