iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在vue中使用flask实现一个视频合成功能
  • 648
分享到

怎么在vue中使用flask实现一个视频合成功能

2023-06-06 19:06:14 648人浏览 独家记忆
摘要

这篇文章给大家介绍怎么在Vue中使用flask实现一个视频合成功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。vue是什么软件Vue是一套用于构建用户界面的渐进式javascript框架,Vue与其它大型框架的区别是

这篇文章给大家介绍怎么在Vue中使用flask实现一个视频合成功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

vue是什么软件

Vue是一套用于构建用户界面的渐进式javascript框架,Vue与其它大型框架的区别是,使用Vue可以自底向上逐层应用,其核心库只关注视图层,方便与第三方库和项目整合,且使用Vue可以采用单文件组件和Vue生态系统支持的库开发复杂的单页应用。

原理:监听drop事件 来获取拖拽的文件列表

怎么在vue中使用flask实现一个视频合成功能
怎么在vue中使用flask实现一个视频合成功能

上传文件

通过axiOS 上传文件

this,.fileList就是我们的文件列表

let files = this.fileList;let fORMd = new FormData();let i = 1;//添加上传列表files.forEach(item => {formd.append(i + "", item, item.name)i++;})formd.append("type", i)let config = {headers: {"Content-Type": "multipart/form-data"}}//上传文件请求axios.post("/qwe", formd, config).then(res => {console.log(res.data)})

flask处理文件

完整代码见最底部

逻辑如下
接收文件
为每次合成请求随机生成一个文件夹 临时保存文件
拼接视频
返回文件路径

@app.route("/file",methods=['POST'])def test(): #获取文件 files = request.files #合成队列 videoL = [] #随机字符串 dirs = sjs() #生成文件夹 os.mkdir(dirs) #保存文件并添加至合成队列 for file in files.values():  print(file)  dst = dirs + "/" + file.name + ".mp4"  file.save(dst)  video = VideoFileClip(dirs + "/" + file.name + ".mp4")  videoL.append(video)  #拼接视频 final = concatenate_videoclips(videoL) #文件路径 fileName = dirs + "/" +"{}.mp4".format(sjs()) #生成视频 final.to_videofile(fileName)  #销毁文件夹 def sc():  shutil.rmtree(dirs)  #30秒后销毁文件夹 timer = threading.Timer(30, sc) timer.start() # 返回文件路径 return fileName

拼接获取文件路径

首先我们看flask

逻辑如下
通过文件名 获取文件 返回文件

app.route("/getvoi",methods=['GET'])def getImg(): #获取文件名 ss = request.args['name'] #文件加至返回响应 response = make_response(  send_file(ss)) #删除文件 def sc():  os.remove(ss)  #30秒后删除文件 timer = threading.Timer(30, sc) timer.start()  return response

前端获取

通过a标签下载

<a s :href="herfs" rel="external nofollow" rel="external nofollow" :download="fileName">下载</a>

herfs如下

怎么在vue中使用flask实现一个视频合成功能

我们上传文件后 通过falsk处理返回文件路径 拼接后获取文件地址

a标签添加download属性可以给下载的文件命名

如果你对/qwe /voi有疑惑 请看下面的配置代理说明

配置代理说明

配置代理是为了解决跨域问题 开发环境可在vue.config.js配置即可使用
生产环境需要额外配置Nginx

怎么在vue中使用flask实现一个视频合成功能

/qwe实际上就是 Http://127.0.0.1:8087/file
/voi实际上就是 http://127.0.0.1:8087/getvoi
对应我们flask中的

怎么在vue中使用flask实现一个视频合成功能

额外说明(如果你使用uni-app)

如果你使用uni-app 可参照文档使用api
上传文件api https://uniapp.dcloud.io/api/request/network-file?id=uploadfile
下载文件api https://uniapp.dcloud.io/api/request/network-file?id=downloadfile
或者直接使用别人封装好的 插件毕竟比较方便

完整代码

如果你不想一个一个复制可以去下载
下载途径1: https://download.csdn.net/download/qq_42027681/15561897
下载途径2:https://GitHub.com/dmhsq/vue-flask-videoSynthesis

flask代码

md5random.py 用于随机字符串生成
import randomimport hashlibdef sjs(): a = random.randint(0, 100) a = "a" + str(a); b = random.randint(100, 10000); b = "b" + str(b); c = hashlib.md5(a.encode(encoding='UTF-8')).hexdigest() + hashlib.md5(b.encode(encoding='UTF-8')).hexdigest(); c = "c" + str(c); d = random.randint(10, 100); d = "d" + str(d); e = hashlib.md5(c.encode(encoding='UTF-8')).hexdigest() + hashlib.md5(d.encode(encoding='UTF-8')).hexdigest(); e = hashlib.md5(e.encode(encoding='UTF-8')).hexdigest() return e;
app_service.py 服务代码
from flask import Flask,request,send_file,make_responseimport os,JSON,threading,shutilfrom moviepy.editor import *from md5random import sjsapp = Flask(__name__)@app.route("/file",methods=['POST'])def test(): #获取文件 files = request.files #合成队列 videoL = [] #随机字符串 dirs = sjs() #生成文件夹 os.mkdir(dirs) #保存文件并添加至合成队列 for file in files.values():  print(file)  dst = dirs + "/" + file.name + ".mp4"  file.save(dst)  video = VideoFileClip(dirs + "/" + file.name + ".mp4")  videoL.append(video) #拼接视频 final = concatenate_videoclips(videoL) #文件路径 fileName = dirs + "/" +"{}.mp4".format(sjs()) #生成视频 final.to_videofile(fileName) #销毁文件夹 def sc():  shutil.rmtree(dirs) #30秒后销毁文件夹 timer = threading.Timer(30, sc) timer.start() # 返回文件路径 return fileName@app.route("/getvoi",methods=['GET'])def getImg(): #获取文件名 ss = request.args['name'] #文件加至返回响应 response = make_response(  send_file(ss)) #删除文件 def sc():  os.remove(ss) #30秒后删除文件 timer = threading.Timer(30, sc) timer.start() return responseif __name__ == '__main__': app.run(host='0.0.0.0',port=8087)

vue代码

演示文件代码

<template> <div> <div  v-on:draGover="tts"  v-on:drop="ttrs"   >  {{ dt }} </div> <div  v-for="(item, index) in fileList"  :key="index"   >  <p    >  {{ item.name }}  </p>  <h6 >  {{ item.type }}  </h6>  <h7 >  {{ item.size | sizeType }}  </h7>  <button  @click="del(index)">删除</button> </div> <!-- 此处为展示最后一个上传的文件 --><!-- <div >--><!--  <img v-if="isImage" :src="srcs"  />--><!--  <video v-if="isVideo" controls :src="srcs" ></video>--><!--  <audio v-if="isAudio" controls :src="srcs" ></audio>--><!-- </div>--> <el-button  type="success" @click="ups()" :disabled="!isCan">合成</el-button> <el-button  v-loading="loading" type="success" >。。。</el-button> <a  type="success" :href="herfs" rel="external nofollow" rel="external nofollow" :download="fileName"><el-button :disabled="isCans"><span >下载</span></el-button></a> <div >文件下载有效时间{{times}}s</div> </div></template><script>import axios from "axios";export default { name: "trs", data() { return {  dt: "",//上传提醒 "拖动到此处上传文件“或者"上传完成,可继续上传"  fileList: [],//文件列表  loading:false,  srcs: "",//图片/视频/音频 base64  isImage: false,//是否是图片  isAudio: false,//是否是音频  isVideo: false,//是否是视频  isCan: true,//是否能合成  isCans:true,//是否能下载  herfs: "",//下载地址  fileName: "",//文件名  times: 25//下载有效时间 }; }, filters: { //格式化文件大小 sizeType(val) {  let kbs = val / 1024;  let mbs = 0;  let gbs = 0;  if (kbs >= 1024) {  mbs = kbs / 1024;  }  if (mbs >= 1024) {  gbs = mbs / 1024;  return gbs.toFixed(2) + "GB";  } else if (mbs >= 1) {  return mbs.toFixed(2) + "MB";  } else {  return kbs.toFixed(2) + "KB";  } } }, mounted() { let vm = this; window.addEventListener("dragdrop", this.testfunc, false); //全局监听 当页面内有文件拖动 提醒拖动到此处 document.addEventListener("dragover", function() {  console.log(111);  vm.dt = "拖动到此处上传文件";  console.log(vm.dt); }); }, methods: { //展示文件 主要为三个类型 图片/视频/音频 readFile(file) {  let vm = this;  let reader = new FileReader();  reader.readAsDataURL(file);  reader.onload = function() {  let type = file.type.substr(0, 5);  if (type == "image") {   vm.isImage = true;   vm.isAudio = false;   vm.isVideo = false;  } else if (type == "audio") {   vm.isImage = false;   vm.isAudio = true;   vm.isVideo = false;  } else if (type == "video") {   vm.isImage = false;   vm.isAudio = false;   vm.isVideo = true;  } else {   alert("不是图片/视频/音频");  }  vm.srcs = reader.result;  // this.$nextTick(()=>{  //  // })  }; }, //全局监听drop的触发事件 取消drop弹窗显示资源 testfunc(event) {  alert("dragdrop!");  //取消drop弹窗显示资源  event.stopPropagation();  event.preventDefault(); }, del(index) {  this.fileList.splice(index, 1);  if (this.fileList.length === 0) {  this.dt = "";  } }, //监听div上传框 当有文件拖动时 显示"拖动到此处上传文件" tts(e) {  console.log(e);  this.dt = "拖动到此处上传文件"; }, //监听div上传框 drop事件触发 ttrs(e) {  console.log(e);  console.log(e.dataTransfer.files);  //获取文件  let datas = e.dataTransfer.files;  //取消drop弹窗显示资源  e.stopPropagation();  e.preventDefault();  datas.forEach(item => {  if(item.type=="video/mp4"){   this.fileList.push(item);  }  });  //读取文件 如果不想展示图片/视频/音频可忽略  this.readFile(this.fileList[this.fileList.length - 1]);  this.dt = "上传完成,可继续上传"; }, //上传文件到服务器 ups(){  if(this.fileList.length==0){  this.$message('文件列表为空');  return ;  }  this.loading = true;  this.isCan = false;  this.isCans = true;  let files = this.fileList;  let formd = new FormData();  let i = 1;  //添加上传列表  files.forEach(item=>{  formd.append(i+"",item,item.name)  i++;  })  formd.append("type",i)  let config={  headers:{"Content-Type":"multipart/form-data"}  }  //上传文件请求  axios.post("/qwe",formd,config).then(res=>{  console.log(res.data)  this.loading = false  //合成下载路径  this.herfs = "/voi?name="+res.data  this.fileName = res.data.split('/')[1]  //禁止合成  this.isCan = false  this.isCans = false  //设置下载有效时间 时间到后无法下载但可以继续合成  let timer = setInterval(()=>{   this.times--;  },1000)  this.setCans(timer)  }) }, setCans(timer){  setTimeout(()=>{  this.isCans = true  this.isCan = true  this.fileName =""  clearInterval(timer)  this.times = 25  },25000) } }};</script><style scoped></style>

vue.config.js

module.exports = { devServer: { // assetsSubDirectory: 'static', // assetsPublicPath: '/', proxy: {  "/qwe": {  target: "http://127.0.0.1:8087/file",  changeOrigin: true,  pathRewrite: {   "^/qwe": ""  }  },  "/voi": {  target: "http://127.0.0.1:8087/getvoi",  changeOrigin: true,  pathRewrite: {   "^/voi": ""  }  } } }};

关于怎么在vue中使用flask实现一个视频合成功能就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

--结束END--

本文标题: 怎么在vue中使用flask实现一个视频合成功能

本文链接: https://www.lsjlt.com/news/248262.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在vue中使用flask实现一个视频合成功能
    这篇文章给大家介绍怎么在vue中使用flask实现一个视频合成功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。vue是什么软件Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是...
    99+
    2023-06-06
  • Python实现多个视频合成一个视频的功能
    目录前言环境依赖代码验证一下前言 本文提供将多个视频拼接为一个视频的Python工具代码,其中有一些限制条件,下面的代码说明会提到。 环境依赖 ffmpeg环境安装,可以参考:win...
    99+
    2024-04-02
  • 使用vue怎么实现一个视频上传功能
    本篇文章为大家展示了使用vue怎么实现一个视频上传功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Vue的优点Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运...
    99+
    2023-06-14
  • 怎么在HTML5中实现一个视频弹幕功能
    这篇文章给大家介绍怎么在HTML5中实现一个视频弹幕功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1>html代码展示<div class="barrage">&nb...
    99+
    2023-06-09
  • 怎么 在HTML5中实现一个语音合成功能
    怎么 在HTML5中实现一个语音合成功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 Speech Synthesis API通过上面的例子我们可以猜测到上面调用的...
    99+
    2023-06-09
  • Android应用中怎么实现一个视频点播功能
    这篇文章给大家介绍Android应用中怎么实现一个视频点播功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。采用了本地代理服务的方式,通过原始url给播放器返回一个本地代理的一个url ,代理URL类似:http://...
    99+
    2023-05-31
    android roi
  • 怎么使用Vue+canvas实现视频截图功能
    这篇“怎么使用Vue+canvas实现视频截图功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么使用Vue+canvas...
    99+
    2023-07-02
  • Android应用中怎么实现一个录制视频生成GIF图片功能
    今天就跟大家聊聊有关Android应用中怎么实现一个录制视频生成GIF图片功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先打开AS,连接上手机,打开你要录制的程序或者视频打开A...
    99+
    2023-05-31
    android roi
  • 怎么用Python实现多个MP4合成视频
    这篇文章主要介绍“怎么用Python实现多个MP4合成视频”,在日常操作中,相信很多人在怎么用Python实现多个MP4合成视频问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python实现多个MP4合...
    99+
    2023-06-20
  • 利用Java实现一个短视频点赞功能
    这篇文章将为大家详细讲解有关利用Java实现一个短视频点赞功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 这行代码是弹出点赞的时间为18s.18秒后发生了什么呢 ?继续看&nb...
    99+
    2023-05-31
    java ava 点赞
  • 怎么在vue中使用django实现一个文件下载功能
    这篇文章将为大家详细讲解有关怎么在vue中使用django实现一个文件下载功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。一、概述在项目中,点击下载按钮,就可以下载文件。传统的下载链接一般...
    99+
    2023-06-14
  • 怎么在Android中利用RecyclerView实现一个频道管理功能
    本篇文章给大家分享的是有关怎么在Android中利用RecyclerView实现一个频道管理功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。需要在build里添加依赖 com...
    99+
    2023-05-31
    recyclerview android recycle
  • 使用vue怎么实现一个倒计时功能
    这期内容当中小编将会给大家带来有关使用vue怎么实现一个倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。通过父组件传入的结束时间减去当前日期得到剩余时间子组件部分<div clas...
    99+
    2023-06-14
  • 怎么在HTML5中实现一个全屏视频背景
    这篇文章将为大家详细讲解有关怎么在HTML5中实现一个全屏视频背景,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。特性自动调整:Bideo.js可以根据当前浏览器窗口的大小自动调整视频尺寸,当...
    99+
    2023-06-09
  • vue中怎么实现一个换肤功能
    这篇文章给大家介绍vue中怎么实现一个换肤功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 色值的选取和原则推荐大家看下蚂蚁金服的设计指引,里面对常见的交互和界面设计有一套不错的指...
    99+
    2024-04-02
  • 如何在vue中使用video实现一个播放器功能
    这期内容当中小编将会给大家带来有关如何在vue中使用video实现一个播放器功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。当现有video播放器不能满足需求时,需要自己对video进行封装。video...
    99+
    2023-06-06
  • 使用vue怎么实现一个转盘抽奖功能
    本篇文章为大家展示了使用vue怎么实现一个转盘抽奖功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Vue的优点Vue具体轻量级框架、简单易学、双向数据绑定、组件化、数据和结构的分离、虚拟DOM、运...
    99+
    2023-06-07
  • 怎么在HTML5中使用Canvas实现一个破碎重组视频特效
    本篇文章为大家展示了怎么在HTML5中使用Canvas实现一个破碎重组视频特效,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。HTML代码<video id="sourcev...
    99+
    2023-06-09
  • 怎么使用Vue实现一个tab栏切换功能
    本篇内容介绍了“怎么使用Vue实现一个tab栏切换功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、创建Vue项目首先需要安装Vue C...
    99+
    2023-07-05
  • 怎么在python中使用PyQt5实现一个窗口功能
    怎么在python中使用PyQt5实现一个窗口功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。python主要应用领域有哪些1、云计算,典型应用OpenSta...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作