如何通过在 nodejs 中上传 CSV 文件来一次添加多个用户?

How to add multiple users at once by upload a CSV file in nodejs?

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

Model.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),
      },
    })

Controller.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"})
    }
}

我该怎么做?

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

1 Parse csv file uploaded: 你可以参考类似的问题: How can I parse data from a csv file uploaded by a user in node/express?

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

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

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 中读取数据后,您可以通过循环数据重用您的逻辑将用户插入数据库。