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

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

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

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

相关推荐

笔记本wifi共享软件(笔记本wifi共享软件怎么设置)

1.打开笔记本电脑的网络设置。在Windows系统中,可以点击任务栏右下角的网络图标,然后点击“网络和Internet设置”。在Mac系统中,可以点击屏幕右上角的WiFi图标,然后点击“打开网络偏好...

电脑游戏界面怎么调成全屏(电脑游戏界面怎么调成全屏模式)

电脑游戏全屏的设置方法:1、使用Alt+enter键将游戏全屏化。2、按win+R快捷键弹出运行,或者点击电脑左下角开始,在开始菜单上找到运行,在运行里输入:regedit;3、进入注册表编辑器后,依...

win7是指什么(win7是啥)

1、win7是美国微软公司在2009年开发的一款操作系统,win7的英文全称是Windows7,中文名称是视窗7,Windows7可供家庭及商业工作环境:笔记本电脑、平板电脑、多媒体中心等使用...

怎么用软碟通制作u盘启动盘(用软碟通做u盘启动盘)

1:首先将U盘插入电脑的USB接口(重要提示:制作过程U盘会被格式化,注意备份资料);  2、解压下载的WinPEU.rar文件;  3、在WinPEU.rar解压目录打开UltraISO.exe程序...

影视大全下载2025免费版下载

1、《战狼》这是一部由吴京、余男、倪大红、阿金斯、周晓鸥等主演,导演为吴京的现代军事战争影片。本片是国内第一部3D动作战争电影,耗时七年全力打造,《战狼2》真实呈现了一场中外边境战争,...

qq账号免费注册(qq帐号免费注册)
  • qq账号免费注册(qq帐号免费注册)
  • qq账号免费注册(qq帐号免费注册)
  • qq账号免费注册(qq帐号免费注册)
  • qq账号免费注册(qq帐号免费注册)
病毒app下载(病毒z下载)
  • 病毒app下载(病毒z下载)
  • 病毒app下载(病毒z下载)
  • 病毒app下载(病毒z下载)
  • 病毒app下载(病毒z下载)
ubuntu系统恢复出厂设置(ubuntu怎么恢复出厂设置)

1、关闭电脑,按住电脑上的开机键,快速按两下按键,然后在出现的画面中选择“引导菜单”,让电脑重新启动;2、在出现的菜单中,选择“恢复或重装系统”;3、在出现的恢复菜单中,选择“系统恢复”;4、选择恢复...

本地组策略命令(本地组策略文件存放在哪)

区别如下供参考:本地安全策略(优先级低):主要应用于当前计算机。组策略(优先级高):可以应用于当前计算机,也可以应用于域中的其他计算机。组策略对象GPO(GroupPolicyObject):组策...

u盘无法制作成启动盘(u盘无法制作成启动盘怎么办)

①主板不支持U盘启动(或支持的不完善);②某些DOS软件(尤其是对磁盘操作类的)对U盘支持的可能不是很好;③U盘是DOS之后出现的新硬件,种类比较繁杂,而且目前绝大多数的USB设备都没有DOS下的驱动...

用一键ghost恢复(一键ghost怎么用还原)
  • 用一键ghost恢复(一键ghost怎么用还原)
  • 用一键ghost恢复(一键ghost怎么用还原)
  • 用一键ghost恢复(一键ghost怎么用还原)
  • 用一键ghost恢复(一键ghost怎么用还原)
手机双系统怎么删除一个(华为手机双系统怎么删除一个)

华为设备上关闭另一个系统,可以按照以下步骤操作:1.登录华为设备的云服务账号,例如华为云账号、Google账号或OneDrive等。2.点击设备页面上的“设置”图标。3.选择“系统”选项。4....

hdd硬盘检测修复工具(hdd检测硬盘坏道)

有很多可以用来检测和诊断硬盘(HDD)的工具,以下是一些常用的硬盘检测工具:1.CrystalDiskInfo:这是一个免费的开源软件,它可以显示硬盘的健康状况、温度、读写速度等信息。2.Hard...

windows vista激活码(windows vista 激活密钥)

WindowsVista不建议免激活。WindowsVista是一款商业软件,需要购买相应的授权,激活才能合法地使用。如果尝试非法方式免激活,可能会导致安全问题和版权纠纷,后果严重。此外,Wind...

您可能没有权限使用网络资源win7

方法如下:1、点击桌面右下角的【网络图标】,在打开的选项中,选择【网络和共享中心】;2、选择【本地连接】,在打开的窗口中,点击【属性】;3、本地连接属性窗口中,双击【Internet协议版本4(...