最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

koa上传excel文件并解析的实现方法

来源:动视网 责编:小采 时间:2020-11-27 22:10:15
文档

koa上传excel文件并解析的实现方法

koa上传excel文件并解析的实现方法:1.中间键使用 koa-body npm install koa-body --save const koaBody = require('koa-body'); app.use(koaBody({ multipart: true, formidable: { maxFileSize: 200 * 1024 * 1024 // 设置上传文件大小最大
推荐度:
导读koa上传excel文件并解析的实现方法:1.中间键使用 koa-body npm install koa-body --save const koaBody = require('koa-body'); app.use(koaBody({ multipart: true, formidable: { maxFileSize: 200 * 1024 * 1024 // 设置上传文件大小最大


1.中间键使用 koa-body

npm install koa-body --save
const koaBody = require('koa-body');

app.use(koaBody({
 multipart: true,
 formidable: {
 maxFileSize: 200 * 1024 * 1024 // 设置上传文件大小最大,默认2M
 }
}));

2.书写路由,croller书写方法

uploadData.js

const errorResult = require('../utils/errorResult.js');
const uploadExcelSrv = require('../service/uploadExcelSrv');

const saveData = async function (ctx, next) {

 const getRes = await uploadExcelSrv.getExcelObjs(ctx);
 if (getRes.status) {
 if (getRes.datas.length > 1) {
 errorResult.errorRes(ctx, '暂时不支持多个sheet存在');
 } else { //得到的是数组
 const objs = getRes.datas[0];
 ctx.body = {
 status: true,
 msg: '上传数据成功'
 };
 }
 } else {
 errorResult.errorRes(ctx, getRes.msg);
 }
 await next();
};
module.exports = {
 saveData
};

3.处理excel存储,解析,处理excel用的库是 xlsx

npm install xlsx --save

uploadExcelSrv.js

//接收上传的excel文件,保存解析返回objects
const xlsx = require('xlsx');
const fs = require('fs');
const path = require('path');
const downPath = path.resolve(__dirname, '../../fileUpload');

async function getExcelObjs (ctx) {
 const file = ctx.request.files.file; // 获取上传文件
 const reader = fs.createReadStream(file.path); // 创建可读流
 const ext = file.name.split('.').pop(); // 获取上传文件扩展名
 const filePath = `${downPath}/${Math.random().toString()}.${ext}`;

 const upStream = fs.createWriteStream(filePath); // 创建可写流
 const getRes = await getFile(reader, upStream); //等待数据存储完成

 const datas = []; //可能存在多个sheet的情况
 if (!getRes) { //没有问题
 const workbook = xlsx.readFile(filePath);
 const sheetNames = workbook.SheetNames; // 返回 ['sheet1', ...]
 for (const sheetName of sheetNames) {
 const worksheet = workbook.Sheets[sheetName];
 const data = xlsx.utils.sheet_to_json(worksheet);
 datas.push(data);
 }
 return {
 status: true,
 datas
 };
 } else {
 return {
 status: false,
 msg: '上传文件错误'
 };
 }
}

function getFile (reader, upStream) {
 return new Promise(function (result) {
 let stream = reader.pipe(upStream); // 可读流通过管道写入可写流
 stream.on('finish', function (err) {
 result(err);
 });
 });
}
module.exports = {
 getExcelObjs
};

文档

koa上传excel文件并解析的实现方法

koa上传excel文件并解析的实现方法:1.中间键使用 koa-body npm install koa-body --save const koaBody = require('koa-body'); app.use(koaBody({ multipart: true, formidable: { maxFileSize: 200 * 1024 * 1024 // 设置上传文件大小最大
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top