如何解决如何从字符串中提取年龄?
这是我的弦
const data = "key=IAfpK,age=58,key=WNVdi,age=64,key=jp90zt,age=47"
我希望输出为[58,64];
我尝试了什么
const filtered = data.replace(/\D+/g,' ').trim().split(' ').map(e => parseInt(e));
console.log(filtered);
解决方法
let data = "key=IAfpK,age=58,key=WNVdi,age=64,key=jp90zt,age=47";
// Split by \s
data = (data.split(/,\s+/));
// Result array
const res = [];
// Loop array
for(let i = 0; i < data.length; i++) {
const el = data[i].split(/\=/);
if(el[0] === "key") res.push({ key: el[1] });
if(el[0] === "age") res.push({ age: el[1] });
}
console.log(res);
或者,如果您只需要数字,请使用此代码。它使用您的字符串,然后用模板(使用指定的replace
的{{1}}方法)进行全局替换,在该模板中将其捕获为RegEx
,然后将这些捕获的每个部分用age=number
符号分割(=
方法),并在等号后仅返回split
。
number
,
您不想这样做。相反,您想用','分割成对:
var pairs = data.split(',');
然后遍历您的配对,并获取名称/值对
var c = pair.split('=');
var name = c[0].trim();
var value = c[1].trim();
类似的东西应该起作用。这是完整的代码:
var results = [];
var pairs = data.split(',');
pairs.forEach(pair => {
var c = pair.split('=');
var name = c[0].trim();
var value = c[1].trim();
if(name == 'age')
results.push(value);
});
,
据我了解您的问题,我想回答。
这样的事情应该可以解决您的情况!
var data = "key=IAfpK,age=47";
var ages = [];
data.split(',').forEach(e => {
var item = e.split('=');
if(item[0] === 'age'){
return ages.push(parseInt(item[1]));
}
});
console.log(ages);
,
const filtered = data.match(/\d+/g).map(Number)
您使用正则表达式(/ \ d + / g)来匹配要查找的内容,即字符串中的数字。过去尝试从字符串作为数组获取数字时,这对我有用。
,
let data = "key=IAfpK,age=47",result = [];
data = data.split(',');
data.forEach(item => {
if(item.indexOf('age=') !== -1)
{
result.push(parseInt(item.trim().split("age=")[1]));
}
})
console.log(result);
,
这将完全提取您想要的内容:
let data = "key=IAfpK,age=47";
let matches = (data.match(/age=([0-9]*?),/g)).map(m => parseInt(m.replace(/age=|,/g,'')))
console.log(matches)
此解决方案的第一部分是:
data.match(/age=([0-9]*?),/g)
该部分与以下内容匹配:age =(numbers),
如果我们有key=IAfpK,
,则完全匹配为:年龄= 58,
那就是第二部分的原因:
.map(m => parseInt(m.replace(/age=|,'')))
在这里,我们翻译匹配项(['age=58,','age=64,']
以得到我们想要的,即“ age =”和“,”之间的元素。
输出,年龄数组:[58,64];
,解析数据可能比仅提取所需内容更有用。我不确定为什么未将47
包含在预期结果中,因此在下面的示例中,我添加了.filter(age => age > 50)
,但是您可以将其更改为您喜欢的任何内容。
const data = "key=IAfpK,age=47";
const pairs = data.split(",").map(pair => pair.split("=",2));
const items = [];
for (const [key,value] of pairs) {
const item = items[items.length - 1];
if (!item || key in item) {
items.push({ [key]: value });
} else {
item[key] = value;
}
}
for (const item of items) {
item.age = parseInt(item.age,10);
}
console.log(items);
console.log(items.map(item => item.age).filter(age => age > 50));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。