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

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

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

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

相关推荐

2025年qq最新版本下载(2021qq最新版本下载)

目前来看的话java版的QQ还是可以用的。.我们需要用那种比较老式的塞班系统手机才能下载安装使用,就目前的时代使用它的意义就看我们自己怎么理解了,不过社会在进步,科技也在发展,要想更强时代的潮流,万物...

cellular版是什么意思(cellular是啥)

  ipad又出了一个cellular版,很多果粉不知道cellular版是什么意思,在购买ipad时也不知道是cellular版好还是wifi版好,要想知道哪一款好得首先了解两个版本的区别。  c...

如何删除ie缓存文件(清楚ie缓存)

1.可以通过清理IE浏览器缓存来解决问题。2.IE浏览器在访问网页时会自动缓存一些网页数据,这样可以提高网页访问速度,但也会占用一定的磁盘空间。如果缓存过多,可能会导致浏览器运行缓慢或出现其他问题...

华为 官翻机(什么是华为官翻机)

华为官翻机指的是华为公司推出的官方翻新手机。官翻机是指经过华为官方认证的二手手机,在严格的检测和修复后重新销售。它们经过了一系列的测试和维修,确保其性能和品质符合华为的标准,并提供一定的保修服务。华为...

应用软件开发(应用软件开发流程)

“人工智能技术应用”,这个词我们多少会了解一点,但是像这种比较高大上的词,我们总是比较模糊,没有准确的概念,总感觉就是那么一回事,那接下来就给大家简单说明一下。人工智能技术应用是属于普通高等学校本科专...

超快精简xp(xp精简软件)

没有具体介绍,可以参考以下XP简化版是一种简化的软件开发方法,旨在提高生产力、降低成本和改进产品质量。其核心原则包括小规模团队、频繁交付、持续集成和测试驱动开发。通过这些原则,XP简化版鼓励开发团队更...

台式机不用无线网卡连wifi(台式机不用无线网卡如何无线上网)

电脑没有无线网卡是无法直接连wifi无线网络的,但是可以使用USB外置无线网卡连接。电脑连接WiFi无线网络是需要有无线网卡的硬件设备才可以正常使用的。如果电脑主板是没有无线网卡硬件配置的可以使用US...

w10系统启动盘u盘(win10系统u盘启动盘)

U盘装系统步骤:1.制作U盘启动盘。这里推荐大白菜U盘启动盘制作工具,在网上一搜便是。2.U盘启动盘做好了,我们还需要一个GHOST文件,可以从网上下载一个ghost版的XP/WIN7/WIN8系统,...

百度网盘旧版本下载(百度网盘旧版本下载方法)

百度网盘文件怎的么下载,方法/步骤分步阅读1/5选中文件进入百度网盘的文件页面,勾选想要下载的文件。2/5点击下载在左下角,点击下载的按钮。3/5点击下载管理在右上角,点击下载管理的图标。4/5点击设...

金山手机卫士安卓版(金山手机卫士官方网站)

您好,进入金山手机卫士软件管理功能里可以在里面点击软件然后进行设置即可。不敢说很准,高查杀率的同时必然会产生高误杀的可能。我最近试用了有些天了,感觉蛮好的,刚装那天帮我扫了个木马出来。今天我同学,刚中...

u盘无法格式化此卷受写保护(u盘无法格式化,此卷受写保护)

方法如下:1、一般的逻辑坏道很好解决,在U盘盘符的上方点击右键,在弹出的窗口中点击属性。2、在打开的属性窗口上部点击工具选项卡,然后在工具选项卡中点击检查。3、在弹出的对话框中点击扫描并修复驱动器,待...

联想底部小孔一键恢复步骤(联想电脑小孔怎么恢复出厂设置)

 (1)在电脑关闭电源的状态下,按下笔记本电脑上那个特殊的按键或使用牙签插入插孔。  (2)电脑会自动开机,并弹出一个“NovoButtonMenu”的选择菜单。选择“SystemRecover...

量产工具下载站(量产工具在哪下载)

检测不到芯片型号的U盘是没有办法找到对应的量产工具的。1、可以用高版本的芯片精灵检测U盘芯片型号,有些情况下是因为工具版本过低不能检测到U盘的的主控芯片型号。2、可以拆开U盘直接查看主控芯片的型号。拆...

电脑开机密码忘记了怎么修改
  • 电脑开机密码忘记了怎么修改
  • 电脑开机密码忘记了怎么修改
  • 电脑开机密码忘记了怎么修改
  • 电脑开机密码忘记了怎么修改
本地组策略编辑器打不开怎么办

1、打开电脑左下角“开始”菜单,找到【运行】选项,点击打开;2、在弹出运行对话框,输入【gpedit.msc】点击确定;3、进入“本地组策略编辑器”,右键点击【计算机配置】下的【...