根据上次出现的、和_拆分字符串

Splitting string based on last occurance of , and _

本文关键字:拆分 字符串      更新时间:2023-09-26

我有一个字符串,看起来像APP1_ENV1、ENV2、ENV3、APP2_ENV4、ENV5、APP3_ENV1如何拆分这个字符串,以便获得类似应用程序的关联数组及其以下env?示例输出-APP1[ENV1,ENV2,ENV3],APP2[ENV4,ENV5],APP3[ENV1]

我想你想要这样的东西

input.replace(/([^,_]+)_((?:[^,_]+,)*?[^,_]+)(?=$|,[^,_]+_)/g, "$1[$2]")

APP1_ENV1,ENV2,ENV3,APP2_ENV4,ENV5,APP3_ENV1
=> APP1[ENV1,ENV2,ENV3],APP2[ENV4,ENV5],APP3[ENV1]
APP1_ENV1,ENV2,ENV3,TREND2_ENV4,ENV5,JADE3_ENV1
=> APP1[ENV1,ENV2,ENV3],TREND2[ENV4,ENV5],JADE3[ENV1]

对于实际的解析,我推荐

input.split(/,(?=[^,_]+_)/g).reduce(function(o, str) {
    var parts = str.split("_");
    o[parts[0]] = parts[1].split(",");
    return o;
}, {});

APP1_ENV1,ENV2,ENV3,APP2_ENV4,ENV5,APP3_ENV1
=> {"APP1":["ENV1","ENV2","ENV3"],"APP2":["ENV4","ENV5"],"APP3":["ENV1"]}
APP1_ENV1,ENV2,ENV3,TREND2_ENV4,ENV5,JADE3_ENV1
=> {"APP1":["ENV1","ENV2","ENV3"],"TREND2":["ENV4","ENV5"],"JADE3":["ENV1"]}
var str = "APP1_ENV1,ENV2,ENV3,APP2_ENV4,ENV5,APP3_ENV1";
var obj = {};
for(var i=1;i<str.split("APP").length;i++){
   var cont = str.split("APP")[i].slice(0,-1);
   obj["APP"+cont.split("_")[0]]=cont.split("_")[1].split(",")
}

现在obj包含

{"APP1":["ENV1","ENV2","ENV3"],"APP2":["ENV4","ENV5"],"APP3":["ENV"]}

根据您的要求。