[英]how to import excel file (XLSX) to mysql using nodejs
我正在尝试将Excel文件中的数据导入到mysql中,就像使用nodejs进行行冒号一样,是否有我可以学习的引用或执行我工作的任何nodejs模块或任何示例代码?
我已经在Google中搜索过,但只看到了mongodb和python的解决方案,
我想到的几种方法:
以csv格式保存要导入的Excel工作表,然后将其导入mysql:cf。 如何将CSV文件导入到MySQL表到目前为止,这是最简单的方法,但是您可能会遇到引号,逗号和其他特质的麻烦。
使用javascript excel解析器读取excel文件并直接用代码执行mysql数据库中的更新:cf。 https://github.com/SheetJS/js-xlsx这个选项比较复杂,但是如果要复制很多文件,它可以使任务自动化。
1.从表单上传csv文件。
2.包括您的配置文件。
看一下下面的代码。
var express = require('express');
var app = express();
var bodyParser = require('body-parser');
var path = require('path');
var http = require('http');
var formidable = require('formidable');
var fs = require('fs');
var csvParser = require('csv-parse');
var cm = require('csv-mysql');
var connection=require('./config');
// Create application/x-www-form-urlencoded parser
var urlencodedParser = bodyParser.urlencoded({ extended: false })
app.use(express.static('public'));
app.get('/csvupload.html', function (req, res) {
res.sendFile(path.resolve("../view/csvupload.html"));
})
app.post('/csvfileupload', urlencodedParser, function (req, res) {
if (req.url == '/csvfileupload') {
var form = new formidable.IncomingForm();
form.parse(req, function (err, fields, files)
{
var oldpath = files.filetoupload.path;
var newpath = 'C:/xampp/htdocs/nodejs/mvc/csvupload/uploads/' + files.filetoupload.name;
fs.rename(oldpath, newpath, function (err) {
if (err) throw err;
res.write('File uploaded and moved!');
res.end();
});
fs.readFile(oldpath, { encoding: 'utf-8' }, function(err, csvData) {
if (err)
{
console.log(err);
}
csvParser(csvData, { delimiter: ',' }, function(err, data) {
if (err)
{
console.log(err);
}
else
{
console.log(data);
var sql = "INSERT INTO customer (id,name,address,designation) VALUES ?";
connection.query(sql, [data], function(err) {
if (err) throw err;
conn.end();
});
}
});
});
});
}
}).listen(8080);
我已经开发了一个可以做到这一点的插件。 这是npm模块的链接: https ://www.npmjs.com/package/xlsx-mysql
和github链接: https : //github.com/Rizwaan-Company/xlsx-mysql
样例代码:
const XLSXtoMYSQL = require('xlsx-mysql');
var optionsZ = {
mysql: {
host: '127.0.0.1',
user: 'root',
database: 'test',
password: 'password',
port: '3306'
},
csv: {
delimiter: '+'
}
}
var locationZ = __dirname + '/file.xlsx';
var waitT = 1000;
XLSXtoMYSQL(locationZ,optionsZ,waitT);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.