我正在使用AWS Lambda服务从S3存储桶上载的CSV文件中读取内容,并将其转换为JSON格式。我在csv到json阶段陷入困境。
const AWS = require('aws-sdk');
const csvtojson = require('csvtojson');
const S3 = new AWS.S3();
exports.handler = async (event,content,callback) => {
console.log(' inside trigger ')
const src_bkt = event.Records[0].s3.bucket.name;
const src_key = event.Records[0].s3.object.key;
try {
const params = {Bucket: src_bkt, Key:src_key}
// get csv file and create stream
const stream = S3.getObject(params).createReadStream();
// convert csv file (stream) to JSON format data
const json = await csvtojson().fromStream(stream);
console.log(json);
}
catch (err) {
console.log(JSON.stringify(err))
return {
statusCode: err.statusCode || 400,
body: err.message || JSON.stringify(err.message)
}
}
};
错误消息: “ errorType”:“ Runtime.ImportModuleError”, “ errorMessage”:“错误:找不到模块'csvtojson'”,
我试图转换lambda上的节点模块以检查运气。请分享任何建议。
答案 0 :(得分:1)
您需要将lambda打包并部署为zip文件。该文件应包含具有处理程序功能的javascript文件以及具有所有依赖项的node_modules
目录。
handler.js
node_modules /
........................ / csvtojson
my-project
为npm init
初始化一个项目文件夹,它将为您创建package.json文件handler.js
中创建处理函数使用npm install csv2json --save
安装csv2json,现在您将看到创建的node_modules
目录
压缩my-project
目录,所以您有my-project.zip,该zip应该直接包含handler.js
和node_modules
参考:
https://aws.amazon.com/premiumsupport/knowledge-center/lambda-deployment-package-nodejs/
希望这会有所帮助。