參考文章

http://librajt.github.io/2013/08/04/handle-excel-file-with-nodejs/

对照了 ExcelJS ,https://github.com/guyonroche/exceljs#create-a-workbook

node-xlsxhttps://github.com/mgcrea/node-xlsx

等 nodejs 等现有组件。决定使用node-xlsx。

node-xlsx 基于现有前端强大组件 js-xlsx。 https://github.com/SheetJS/js-xlsx

简单使用样例:

var express = require('express');
var router = express.Router();
var xlsx = require('node-xlsx');
var fs = require('fs'); /* GET import excel test. */
router.get('/importExcel', function(req, res, next) {
var filename='./public/test.xlsx';
console.error(filename);
// read from a file
var obj = xlsx.parse(filename);
console.log(JSON.stringify(obj)); res.send('import successfully!');
});
/* GET export excel test. */
router.get('/exportExcel', function(req, res, next) {
// write
var data = [[1,2,3],[true, false, null, 'sheetjs'],['foo','bar',new Date('2014-02-19T14:30Z'), '0.3'], ['baz', null, 'qux']];
var buffer = xlsx.build([{name: "mySheetName", data: data}]);
fs.writeFileSync('b.xlsx', buffer, 'binary');
res.send('export successfully!'); });

补充:

文件上传操作能够选择下面两种

fs                           https://github.com/jprichardson/node-fs-extra

formidable   https://github.com/felixge/node-formidable

上传參考代码1: http://www.tuicool.com/articles/F7JrMjj

             https://cnodejs.org/topic/4f40a4dc0feaaa4424081758

上传文件  (记得创建上传文件的文件夹,比如public/upload )

routes/test.js

var formidable = require('formidable');
var http = require('http');
var util = require('util');
var express = require('express');
var fs = require('fs');
var path = require('path');
var favicon = require('serve-favicon');
var bodyParser = require('body-parser'); var app = express();
var server = http.createServer(app); server.listen(3000); app.set('views', '/views');
//app.use(favicon('/public/favicon.ico'));
app.use(bodyParser());
app.use('/public',express.static(path.join(__dirname, 'public'))); app.get('/',function(req, res) { res.writeHead(200, {'content-type': 'text/html'});
res.end(
'<form action="/upload" enctype="multipart/form-data" method="post">'+
'<input type="text" name="title"><br>'+
'<input type="file" name="upload" multiple="multiple"><br>'+
'<input type="submit" value="Upload">'+
'</form>'
);
}); app.post('/upload', function(req,res) {  console.log(" ########## POST /upload ####### ");
    var fileTypeError = false;
    var target_path = __dirname+"/upload";
    var form = new formidable.IncomingForm();
    form.encoding = 'utf-8';
    form.keepExtensions = true;
    form.maxFieldsSize = 10 * 1024 * 1024;
    form.uploadDir = target_path;     var fields = [];
    var files = [];     form.on('field', function (field, value) {
        fields.push([field, value]);
    });
    form.on('file', function (field, file) {
        console.log('upload file: ' + file.name);
       //推断文件类型是否是xlsx
        if (file.type != 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {
            fileTypeError = true;
        }
        files.push([field, file]);
    });     form.on('end', function () {         //遍历上传文件
        var fileName = '';
        var obj = '';
        var folder_exists = fs.existsSync(target_path);
        if (folder_exists) {
            var dirList = fs.readdirSync(target_path);
            dirList.forEach(function (item) {
                if (!fs.statSync(target_path + '/' + item).isDirectory()) {
                    console.log('parse item:' + target_path + '/' + item);
                    fileName = target_path + '/' + item;
                    if (!fileTypeError) {
                        //解析excel
                        obj = xlsx.parse(fileName);
                        console.log(JSON.stringify(obj));
                        //insert into DB
                        //todo
                        res.send({"rtnCode": "0", "rtnInfo": "成功导入数据"});
                    } else {
                        res.send({"rtnCode": "1", "rtnInfo": "文件格式不对"});
                    }
                    //delete file
                    fs.unlinkSync(fileName);                 }
            });
        }else{
            res.send({"rtnCode": "1", "rtnInfo": "系统错误"});
        }     });
    form.on('error', function(err) {
        res.send({"rtnCode": "1", "rtnInfo": "上传出错"});
    });
    form.on('aborted', function() {
        res.send({"rtnCode": "1", "rtnInfo": "放弃上传"});
    });
    form.parse(req); });

其它參考://返回上传进度

form.on('progress', function(bytesReceived, bytesExpected) {
var progress = {
type: 'progress',
bytesReceived: bytesReceived,
bytesExpected: bytesExpected
}; socket.broadcast(JSON.stringify(progress));
});

最新文章

  1. css文件 引用后不起作用
  2. hosts文件的一个小发现
  3. Ruby中Block, Proc, 和Lambda
  4. Python 集合操作
  5. android: 使用通知
  6. oracle user account locked
  7. MATLAB实现矩阵分块相乘
  8. [Uva 10085] The most distant state (BFS)
  9. 【暑假】[实用数据结构]UVAlive 3135 Argus
  10. Silverlight之Styles和Behaviors
  11. RS485连接CAN&mdash;&mdash;应急用法【worldsing笔记】【待完善】
  12. JPEG图像密写研究(一) JPEG图像文件结构
  13. perl 继承概述
  14. 【iOS】彩虹渐变色 的 Swift 实现
  15. KoaHub平台基于Node.js开发的Koa的连接MongoDB插件代码详情
  16. CRT工具远程登陆Google Cloud远程ssh登录方法
  17. springcloud第八步:hystrix解决服务雪崩
  18. Log4J.xml配置详解
  19. 莫烦theano学习自修第八天【分类问题】
  20. Dynamic CRM 2016 的备份/恢复/重新部署

热门文章

  1. HTML5 Canvas 动态勾画等速螺线
  2. 在html页面中直接嵌入图片数据
  3. dev_queue_xmit()函数返回值问题
  4. wmi在渗透测试中的运用
  5. Python3的bytes/str之别
  6. java8 lambda 与 stream
  7. Linux终端:speedtest_cli检测你的实时带宽速度
  8. 01-1制作U盘启动盘--大白菜超级U盘启动盘制作工具
  9. 转Postman请求Https接口
  10. LINQ使用与并行