JavaScript:从表配置字符串中提取列标题

时间:2012-07-25 07:58:15

标签: javascript regex string

我需要帮助在Javascript中抓取一些字符串操作。我有一个示例字符串

var str = 'Supplier^supp^left^string*Spend (USD MM)^spend^right^number^5';

该字符串基本上是两列的portlet配置,因为Supplier和Spend ..我必须从此字符串中获取列名。每颗星都遵循新的列配置。在这种情况下,只有2列的配置,因此我的字符串中只存在1个星。据说如果有2列,字符串看起来像

var str = 'Supplier (Name)^Supplier^left^string*Spend (USD MM)^Spend^right^number^5*Location (Area)^Loc^right^string^*Category ^Categ^right^string';

所以从上面的字符串我写了一个逻辑来获得所需的字符串 在第二个插入符号之后我想要'供应商'(第一列数据名称而不是'供应商(名称),这是一个显示名称),(在明星之后移动到第二列)在第二个插入符'花'之后。类似'Loc'(第三列)和'分类'(第4列)。任何人都可以帮我实现这个目标吗?这是我写的

    function getColNamesfromConfig(str) {
        var i = str.indexOf('^');
        var tmpCatStr = str.slice(i + 1);
        var catField = tmpCatStr.slice(0, tmpCatStr.indexOf('^'));

        var j = tmpCatStr.indexOf('*');
        var tmpStr = tmpCatStr.slice((j + 1));
        var k = tmpStr.slice(tmpStr.indexOf('^') + 1);
        var valField = k.slice(0, k.indexOf('^'));
        return { categoryField: catField, valueField: valField };
    }

2 个答案:

答案 0 :(得分:3)

您可以使用split()

str.split('*')[0].split('^')[1]

上面的代码会给你

Supplier

检查以下link

答案 1 :(得分:0)

或者使用正则表达式:

   function headers(s) {
      var re = /([^^]+)(?:[^*]+[*]?)?/g, names=[];
      while (match = re.exec(s)) {
        names.push(match[1]);
      }
      return names;
   }

输出     ["Supplier","Spend (USD MM)","Location (Area)","Category "] 和     ["Supplier (Name)","Spend (USD MM)","Location (Area)","Category "] 对于你的两个例子

在行动中查看此内容(JSFiddle)。