首页 > 解决方案 > 如何通过在nodejs中上传CSV文件一次添加多个用户?

问题描述

我有一个用户模型。我创建了一个控制器来添加一个新用户。但我想通过上传 CSV 文件一次添加多个用户。新用户存储在数据库中。CSV 文件包含 3 列:first_name、last_name、email。我怎么解决这个问题?

模型.js

 const User = sequelize.define(
    "users",
    {
      id: {
        type: Sequelize.BIGINT(20),
        allowNull: false,
        autoIncrement: true,
        primaryKey: true,
      },
      first_name: {
        type: Sequelize.STRING(60),
      },
      last_name: {
        type: Sequelize.STRING(60),
      },
      email: {
        type: Sequelize.STRING(255),
      },
    })

控制器.js

const addUser = async(req, res) => {
    try {

        console.log(req.body);
        let { first_name, last_name, email } = req.body

        const newUser = await User.create({
            first_name,
            last_name,
            email
        }) 
        return res.status(201).json({ error: false, msg: "Add Successfuly", data: newUser})
    } catch (error) {

        return res.status(500).json({ error: true, msg: "Server Error"})
    }
}

我怎样才能做到这一点?

标签: mysqlnode.jsexpresssequelize.js

解决方案


您可以将问题分解为两个:

1 解析上传的csv文件:可以参考类似的问题: 如何解析用户在node/express中上传的csv文件中的数据?

您可以使用此节点模块来解析 csv 文件。https://www.npmjs.com/package/csvtojson

例如,您在请求对象中有文件名用户。

const csv=require('csvtojson');

csv()
.fromString(req.files.users.data.toString('utf8'))
.on('json', (user) => {
    console.log(user);
})
.on('done', () => {
    console.log('done parsing');
});

2 从上传的 csv 读取数据后,您可以重用您的逻辑,通过循环数据将用户插入数据库。


推荐阅读