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

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

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

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

相关推荐

原来的hotmail邮箱去哪登陆(hotmail邮箱账号)
  • 原来的hotmail邮箱去哪登陆(hotmail邮箱账号)
  • 原来的hotmail邮箱去哪登陆(hotmail邮箱账号)
  • 原来的hotmail邮箱去哪登陆(hotmail邮箱账号)
  • 原来的hotmail邮箱去哪登陆(hotmail邮箱账号)
笔记本用的无线网卡(笔记本用的无线网卡最新型号)

谈一下USB无线网卡选购的经验。无线网卡的技术规格主要是802.11n和802.11ac两种。11n支持2.4g和5g无线频段,有的设备只支持2.4g,称为单频;有的设备支持两个频段,称为双频。11a...

移动u盘怎么格式化(移动u盘格式化是什么意思)

您好,要格式化移动U盘,可以按照以下步骤进行操作:1.将移动U盘插入计算机的USB接口。2.打开“我的电脑”或“此电脑”(Windows系统)或“查看器”(Mac系统)。3.在资源管理器(Win...

电脑突然出现蓝屏英文要怎么处理
电脑突然出现蓝屏英文要怎么处理

1.电脑蓝屏出现英文,可能是电脑系统或硬件故障等原因所导致。最好前往售后服务点请专业人员进行检测处理。以华为笔记本电脑MateBook14,windows10系统为例,在华为手机上,打开我的华为应用。2.先点击服务,再点击到店维修。...

2026-01-18 21:05 liuian

百度 网盘(百度网盘官网)

使用方便,可以存储大量数据,照片文档。在电脑上和手机上都可以使用,很节省设备的空间。但是下载速度慢,有时莫名其妙会被限速,很好用,容量很大,资源也丰富,而且功能很多,不过建议您开通会员使用,体验提升...

2008序列号激活码(2008 r2激活码)

win2008r2密钥序列号如下::ServerStandard标准版安装密钥:YC6KT-GKW9T-YTKYR-T4X34-R7VHC33PXH-7Y6KF-2VJC9-XBBR8-HVT...

win7怎样设置启动项(怎么设置win7开机启动项)

a,在BIOS中寻找BOOT选项,并找到LaunchCSM设置(CSM的意思是兼容模式,其主板设置要求要开启才能正常启动Windows),设置为Enabled(开启)。b,在BIOS中寻找Secur...

笔记本显示未安装音频设备(电脑音频设备显示未安装)

如果笔记本显示未安装任何音频输出设备,可以尝试以下几种解决方法:1.重新插拔音频设备:检查并重新插拔笔记本上的耳机或扬声器插头。确保插头已完全插入音频接口。2.更新驱动程序:检查音频设备的驱动程序...

电脑突然自己关机了怎么回事

电脑突然关机可能有多种原因,以下是一些常见的原因:1.电源问题:电源故障或电压不稳定可能导致电脑突然关机。检查电源插头和电源线是否连接牢固,以及电源是否正常工作。2.过热:电脑长时间高负荷运行,导...

windows设备管理器(windows设备管理器英文)

第一种,命令打开任务管理器点击【开始】-->【运行】,打开运行窗口。在文本行里面输入【devmgmt.msc】,然后点击【确定】按钮,执行该命令。第二种,通过我的电脑【我的电脑】上面点击鼠标右键...

如何更改开机启动项(修改开机启动项)

在Windows操作系统中,你可以按照以下步骤修改开机启动项:1.打开任务管理器:按下Ctrl+Shift+Esc键组合或者右击任务栏空白处并选择“任务管理器”。2.在任务管理器中,切换到...

msdn下载的xp系统怎么安装(xp安装msu文件)

在安装XP系统时,如果使用MSDN的ISO文件进行安装,可能会遇到装不了的情况。原因可能是ISO文件本身存在问题,需要重新下载或使用其他渠道获取。另外,也有可能是光盘刻录出现问题,需要检查光盘质量或更...

melogincncn登录页面(melogincn登录界面登录)

路由器melogincn手机无法登陆进去表现为系统闪退,原因和解决方法如下Root后修改文件  现在很多用户都选择Root(越狱)来获得更多使用权限,尤其是美化字体,这时候如果所替换的字体字库不全,应...

下载windows系统的网址(下载windows10网站叫什么)

通过优酷网网站可以直接下载mp4格式的电影和视频,不过可以下载后使用EV视频转换器将视频转换为mp4格式的视频。下载“硕鼠”软件,在硕鼠里直接粘帖视频的链接,不需要下载客户端就可以下载视频,并且可以选...

qq文件恢复软件(qq文件恢复软件哪个好用)

如果还能让对方重新发一下文件,那就直接重发一下比较好。如果无法重发了,就只能使用数据恢复软件尝试恢复了。找个恢复软件来搜索丢失数据的分区,即本地文件所保存的分区,例如D盘、C盘等。如果软件可以搜索到并...