对文本内容进行FIlter处理,并尝试将过滤后的内容转换成JSON格式。

问题描述 投票:0回答:1

我有一个以字符串变量msg.payload形式的输入,如下所示。

Hi Team,
Below are the details of for the given source platform.
name=abc
status=Active
company=Discovery
FromDate=6/05/2020
ToDate=20/05/2020
Please do the needful ASAP
Thanks & Regards,
xyz

我想只取

name=abc
status=Active
company=Discovery
FromDate=6/05/2020
ToDate=20/05/2020

其余的就不用管了,然后用JavaScript将其转换为JSON,如

{"name":"abc", "status":"Active","company":"ABCD" ,"FromDate":"6/05/2020","ToDate":"20/05/2020"}

如何实现呢?输入中的所有数据都是 key=value 的形式。

javascript node.js json node-red
1个回答
1
投票

你可以利用几个内置的JavaScript字符串和数组函数。

用以下函数将输入转换为一个数组行 String.prototype.split():

const lines = input.split('\n');

筛选出不含等号的行,用 "等号 "过滤。Array.prototype.filter():

const kvPairs = lines.filter(line => line.includes('='));

使用 Array.prototype.forEach()String.prototype.split() 来加载带有键值属性的对象。

let object = {};
kvPairs.forEach(line => {
  [key, val] = line.split('=');
  object[key] = val;
});

把它放在一起。

const input = 'Hi Team,\nBelow are the details of for the given source platform.\nname=abc\nstatus=Active\ncompany=Discovery\nFromDate=6/05/2020\nToDate=20/05/2020\nPlease do the needful ASAP\nThanks & Regards,\nxyz';

const lines = input.split('\n');

const kvPairs = lines.filter(line => line.includes('='));

let object = {};
kvPairs.forEach(line => {
  [key, val] = line.split('=');
  object[key] = val;
});

console.log('object:', object);
© www.soinside.com 2019 - 2024. All rights reserved.