【问题标题】:How to extract age from a string?如何从字符串中提取年龄?
【发布时间】:2020-08-14 17:24:22
【问题描述】:

这是我的字符串 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);

【问题讨论】:

  • 在您的示例输出中,应该是[58, 64, 47] 吗?或者您是否希望出于某种原因省略字符串中的最后一个年龄?

标签: javascript string text-extraction


【解决方案1】:

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);

或者,如果您只需要数字,请使用此代码。它获取您的字符串,然后使用模板进行全局替换(具有指定 RegExreplace 方法),其中它将部分捕获为 age=number,然后这些捕获的部分中的每一个都使用 = 拆分符号(split 方法)并在等号后仅返回 number

let data = "key=IAfpK, age=58, key=WNVdi, age=64, key=jp90zt, age=47";

// Parse
const matched = data.replace(/(?:key=.*?)age=(\d+)/g, (m) => m.split(/\=/)[2]);

// Log
console.log(matched);

【讨论】:

  • 赞成。我喜欢你的第二个例子,但你能解释一下它的作用吗?
  • 它获取您的字符串,然后使用模板进行全局替换(具有指定RegExreplace 方法),其中将部分捕获为age=number,然后捕获每个部分部分用= 符号(split 方法)分割,只返回等号后的数字。
  • 感谢您的解释。请您在答案部分更新它,以便其他人可以看到它。
【解决方案2】:

据我了解您的问题,我想回答一下。
这样的事情应该可以解决您的问题!

var data = "key=IAfpK, age=58, key=WNVdi, age=64, key=jp90zt, 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);

【讨论】:

    【解决方案3】:
    const filtered = data.match(/\d+/g).map(Number)
    

    您使用正则表达式 (/\d+/g) 来匹配您要查找的内容,即字符串中的数字。过去,当我尝试从字符串中获取数字作为数组时,这对我有用。

    【讨论】:

      【解决方案4】:

      你不想那样做。相反,你想先用','分割来得到你的对:

      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);
      });
      

      【讨论】:

        【解决方案5】:

        let data = "key=IAfpK, age=58, key=WNVdi, age=64, key=jp90zt, 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);

        【讨论】:

          【解决方案6】:

          这将准确提取您想要的内容:

          let data = "key=IAfpK, age=58, key=WNVdi, age=64, key=jp90zt, 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, age=58,,则完整匹配将是:age=58, 这就是第二部分的原因:

          .map(m => parseInt(m.replace(/age=|,/g, '')))
          

          在这里,我们翻译匹配项 (['age=58,', 'age=64,']) 以获得我们想要的内容,即“age=”和“,”之间的元素。

          输出,年龄数组:[58, 64];

          【讨论】:

            【解决方案7】:

            解析数据可能比仅提取您需要的数据更有用。我不确定为什么 47 不包含在预期结果中,所以在下面的示例中我添加了 .filter(age =&gt; age &gt; 50),但您可以将其更改为您喜欢的任何内容。

            const data = "key=IAfpK, age=58, key=WNVdi, age=64, key=jp90zt, 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));

            【讨论】:

              猜你喜欢
              • 1970-01-01
              • 2021-03-27
              • 1970-01-01
              • 1970-01-01
              • 2021-05-10
              • 1970-01-01
              • 1970-01-01
              • 2021-05-06
              • 2016-11-05
              相关资源
              最近更新 更多