电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

vue + node如何通過一個Txt文件批量生成MP3并壓縮成Zip

瀏覽:27日期:2023-01-16 16:41:31

看看效果叭

vue + node如何通過一個Txt文件批量生成MP3并壓縮成Zip

解壓的文件

vue + node如何通過一個Txt文件批量生成MP3并壓縮成Zip

上傳的文件格式

測試1|||測試1的文字測試2|||測試2的文字測試3|||測試3的文字測試4|||測試4的文字測試5|||測試5的文字

實現的邏輯如下

上傳文件 解析txt 發送內容至百度語音合成 生成文件夾放置本次合成的mp3文件,并壓縮成zip 發送zip的地址給前端

使用了 element-ui 的 el-upload 組件

<el-upload v-loading='loading' drag ref='upload' action='#' accept='.txt' :before-upload='onBeforeUploadImage' :http-request='UploadImage' :on-change='fileChange' :file-list='fileList' > <i class='el-icon-upload'></i> <div class='el-upload__text'> 將文件拖到此處,或 <em>點擊上傳</em> </div> <div slot='tip'>只能上傳txt文件,且不超過1M</div></el-upload>

在上傳之前判斷上傳的文件是否符合要求

onBeforeUploadImage(file) { const isTxt = file.type === 'text/plain'; const isLt1M = file.size / 1024 / 1024 < 1; if (!isTxt) { this.$message.error('上傳文件只能是txt格式!'); } if (!isLt1M) { this.$message.error('上傳文件大小不能超過 1MB!'); } return isTxt && isLt1M;}

一次只上傳一個文件,在文件列表更新時先清除之前的文件

fileChange(file) { let obj = this.onBeforeUploadImage(file.raw); if (obj) { this.$refs.upload.clearFiles(); this.fileList = [{ name: file.name, url: file.url }]; }}

上傳的主要函數

UploadImage(param) { this.loading = true; const formData = new FormData(); formData.append('file', param.file); this.$axios({ url: process.env.VUE_APP_BASE_API + 'api/txtToMp3', method: 'post', data: formData }) .then(response => { if (response.data.code == 0) { this.loading = false; this.dialogVisible = true; this.url = response.data.data.url; } }) .catch(error => { console.log(error); });}

node代碼

用到的依賴項

const formidable = require('formidable'); //獲取上傳的txt,并保存const path = require('path'); const AipSpeech = require('baidu-aip-sdk').speech; //百度語音合成sdkconst fs = require('fs'); const compressing = require('compressing'); //壓縮文件夾用

接口代碼

router.post('/txtToMp3', async function (req, res, next) { let form = new formidable.IncomingForm(); form.encoding = 'utf-8'; //編碼 form.uploadDir = path.join(__dirname + '/../txt'); //保存上傳文件地址 form.keepExtensions = true; //保留后綴 form.parse(req, function (err, fields, files) { let filename; filename = files.file.name; let nameArray = filename.split('.'); //分割 let type = nameArray[nameArray.length - 1]; let name = ''; for (let i = 0; i < nameArray.length - 1; i++) { name = name + nameArray[i]; } let date = new Date(); let time = '_' + date.getTime(); let avatarName = name + time + '.' + type; let newPath = form.uploadDir + '/' + avatarName; fs.renameSync(files.file.path, newPath); //移動文件 fs.readFile(newPath, 'utf-8', function (err, data) { if (err) { console.log(err); new Result(null, '讀取失敗').fail(res); } else { let client = new AipSpeech( 0, '百度語音合成key', '百度語音合成secret' ); let resultData = data.split('n'); let number = resultData.length; let formTime = new Date().getTime(); let mp3FileDir = path.join(__dirname + '/../mp3_' + formTime); fs.mkdirSync(mp3FileDir); for (let i in resultData) { setTimeout(function(){if (resultData[i].indexOf('|||') != -1) {let text = resultData[i].split('|||')[1];// 語音合成,保存到本地文件client.text2audio(text, { spd: 4, per: 4 }).then( function (result) { if (result.data) { let time = resultData[i].split('|||')[0] + '_voice'; let avatarName_mp3 = mp3FileDir + '/' + time + '.mp3'; fs.writeFileSync(avatarName_mp3, result.data); number--; if (number == 0) { let zipFileName = 'zip/mp3_' + formTime + '.zip'; compressing.zip .compressDir(mp3FileDir, zipFileName) .then(() => { let item = { url: zipFileName, }; new Result(item, '壓縮成功').success(res); }) .catch((err) => { new Result(null, '壓縮失敗').fail(res); }); } } else { // 合成服務發生錯誤 new Result(null, '合成失敗').fail(res); } }, function (err) { console.log(err); }); } else {new Result(null, '文件格式錯誤').fail(res); }},i * 20) } } }); });});

PS:

在node部分,在判斷需要合成的文件是否全部完成時,我是通過number的值等于0判斷完成,不知道大佬們有啥好方法不?

到此這篇關于vue + node如何通過一個Txt文件批量生成MP3并壓縮成Zip的文章就介紹到這了,更多相關vue node批量生成MP3內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
主站蜘蛛池模板: 贝朗斯动力商城(BRCPOWER.COM) - 买叉车蓄电池上贝朗斯商城,价格更超值,品质有保障! | 环氧乙烷灭菌器_压力蒸汽灭菌器_低温等离子过氧化氢灭菌器 _低温蒸汽甲醛灭菌器_清洗工作站_医用干燥柜_灭菌耗材-环氧乙烷灭菌器_脉动真空压力蒸汽灭菌器_低温等离子灭菌设备_河南省三强医疗器械有限责任公司 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 吲哚菁绿衍生物-酶底物法大肠菌群检测试剂-北京和信同通科技发展有限公司 | 压力变送器-上海武锐自动化设备有限公司| 液压中心架,数控中心架,自定心中心架-烟台恒阳机电设计有限公司 行星搅拌机,双行星搅拌机,动力混合机,无锡米克斯行星搅拌机生产厂家 | 金属管浮子流量计_金属转子流量计厂家-淮安润中仪表科技有限公司 | 广州番禺搬家公司_天河黄埔搬家公司_企业工厂搬迁_日式搬家_广州搬家公司_厚道搬迁搬家公司 | 比亚迪叉车-比亚迪电动叉车堆垛车托盘车仓储叉车价格多少钱报价 磁力去毛刺机_去毛刺磁力抛光机_磁力光饰机_磁力滚抛机_精密金属零件去毛刺机厂家-冠古科技 | 超声波清洗机_细胞破碎仪_实验室超声仪器_恒温水浴-广东洁盟深那仪器 | 衬氟旋塞阀-卡套旋塞阀-中升阀门首页 | 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 厂房出租_厂房出售_产业园区招商_工业地产&nbsp;-&nbsp;中工招商网 | 成都离婚律师|成都结婚律师|成都离婚财产分割律师|成都律师-成都离婚律师网 | 【甲方装饰】合肥工装公司-合肥装修设计公司,专业从事安徽办公室、店面、售楼部、餐饮店、厂房装修设计服务 | 大行程影像测量仪-探针型影像测量仪-增强型影像测量仪|首丰百科 大通天成企业资质代办_承装修试电力设施许可证_增值电信业务经营许可证_无人机运营合格证_广播电视节目制作许可证 | 铣刨料沥青破碎机-沥青再生料设备-RAP热再生混合料破碎筛分设备 -江苏锡宝重工 | 电磁辐射仪-电磁辐射检测仪-pm2.5检测仪-多功能射线检测仪-上海何亦仪器仪表有限公司 | 塑料异型材_PVC异型材_封边条生产厂家_PC灯罩_防撞扶手_医院扶手价格_东莞市怡美塑胶制品有限公司 | 厦门网站建设_厦门网站设计_小程序开发_网站制作公司【麦格科技】 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 生态板-实木生态板-生态板厂家-源木原作生态板品牌-深圳市方舟木业有限公司 | 产业规划_产业园区规划-产业投资选址及规划招商托管一体化服务商-中机院产业园区规划网 | 密封圈_泛塞封_格莱圈-[东莞市国昊密封圈科技有限公司]专注密封圈定制生产厂家 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 好物生环保网、环保论坛 - 环保人的学习交流平台 | 代写标书-专业代做标书-商业计划书代写「深圳卓越创兴公司」 | 博医通医疗器械互联网供应链服务平台_博医通| 天津电机维修|水泵维修-天津晟佳机电设备有限公司 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | LED灯杆屏_LED广告机_户外LED广告机_智慧灯杆_智慧路灯-太龙智显科技(深圳)有限公司 | 岩石钻裂机-液压凿岩机-劈裂机-挖改钻_湖南烈岩科技有限公司 | 团建-拓展-拓展培训-拓展训练-户外拓展训练基地[无锡劲途] | 十二星座查询(性格特点分析、星座运势解读) - 玄米星座网 | B2B网站_B2B免费发布信息网站_B2B企业贸易平台 - 企资网 | 充气膜专家-气膜馆-PTFE膜结构-ETFE膜结构-商业街膜结构-奥克金鼎 | 青岛美佳乐清洁工程有限公司|青岛油烟管道清洗|酒店|企事业单位|学校工厂厨房|青岛油烟管道清洗 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | 变频器维修公司_plc维修_伺服驱动器维修_工控机维修 - 夫唯科技 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | SF6环境监测系统-接地环流在线监测装置-瑟恩实业 | 水厂自动化-水厂控制系统-泵站自动化|控制系统-闸门自动化控制-济南华通中控科技有限公司 |