使用javascript获取两个字符之间的子字符串


194

我试图从一个较大的字符串中提取一个字符串,使它在':'和';'之间得到一切。

当前

Str = 'MyLongString:StringIWant;'

期望的输出

newStr = 'StringIWant'

Answers:


424

你可以试试这个

var mySubString = str.substring(
    str.lastIndexOf(":") + 1, 
    str.lastIndexOf(";")
);

4
简单的解决方案但方便,尤其是在要避免使用正则表达式的情况下。
Nikolay Frick

8
有谁知道我在开始和结束字符串之间的子字符串的每次出现都会如何做?
MarksCode '16

6
@VirtualTroll 8秒?天哪,我想看看您的“解决方案”:D
汤姆,

@tom尽管没有上下文的“ 8秒”没有任何有意义的信息-但我很确定这与一次运行没有区别)
ego

7
我确定他的意思是这个答案早于他的8秒钟发布了。在他写的时候。
MaxSantos

110

您也可以尝试以下操作:

var str = 'one:two;three';    
str.split(':').pop().split(';')[0]; // returns 'two'

13
没有正则表达式。爱它。
flimflam57

str.split(':').pop().split(';')[0]可能比使用速度更快.shift()
MysteryPancake

48

split()

var s = 'MyLongString:StringIWant;';
var arrStr = s.split(/[:;]/);
alert(arrStr);

arrStr将包含所有以:或分隔的字符串,;
因此通过访问每个字符串for-loop

for(var i=0; i<arrStr.length; i++)
    alert(arrStr[i]);

我想要的字符串在[]和这是行不通的...例如:'MyLongString [StringIWant]'。split(/ [[]] /);
菲利普(Philippe)

1
@Philippe对于您的用例,请使用此正则表达式\[(.*?)\] --->简而言之,您需要转义方括号,因为[]表示正则表达式中的字符类。
asifsid88 '18

33

@Babasaheb Gosavi如果出现一次子字符串(“:”和“;”),则答案是完美的。但是一旦发生多次,可能会有些棘手。


我想出的用于多个项目的最佳解决方案是在一个对象内部使用四种方法。

  • 第一种方法:实际上是从两个字符串之间获取一个子字符串(但是只会找到一个结果)。
  • 第二种方法:将删除(可能是)最近发现的结果以及其前后的子字符串。
  • 第三种方法:将在字符串上递归执行上述两种方法。
  • 第四种方法:将应用第三种方法并返回结果。

如此多的讨论,让我们看一下代码:

var getFromBetween = {
    results:[],
    string:"",
    getFromBetween:function (sub1,sub2) {
        if(this.string.indexOf(sub1) < 0 || this.string.indexOf(sub2) < 0) return false;
        var SP = this.string.indexOf(sub1)+sub1.length;
        var string1 = this.string.substr(0,SP);
        var string2 = this.string.substr(SP);
        var TP = string1.length + string2.indexOf(sub2);
        return this.string.substring(SP,TP);
    },
    removeFromBetween:function (sub1,sub2) {
        if(this.string.indexOf(sub1) < 0 || this.string.indexOf(sub2) < 0) return false;
        var removal = sub1+this.getFromBetween(sub1,sub2)+sub2;
        this.string = this.string.replace(removal,"");
    },
    getAllResults:function (sub1,sub2) {
        // first check to see if we do have both substrings
        if(this.string.indexOf(sub1) < 0 || this.string.indexOf(sub2) < 0) return;

        // find one result
        var result = this.getFromBetween(sub1,sub2);
        // push it to the results array
        this.results.push(result);
        // remove the most recently found one from the string
        this.removeFromBetween(sub1,sub2);

        // if there's more substrings
        if(this.string.indexOf(sub1) > -1 && this.string.indexOf(sub2) > -1) {
            this.getAllResults(sub1,sub2);
        }
        else return;
    },
    get:function (string,sub1,sub2) {
        this.results = [];
        this.string = string;
        this.getAllResults(sub1,sub2);
        return this.results;
    }
};

如何使用?

例:

var str = 'this is the haystack {{{0}}} {{{1}}} {{{2}}} {{{3}}} {{{4}}} some text {{{5}}} end of haystack';
var result = getFromBetween.get(str,"{{{","}}}");
console.log(result);
// returns: [0,1,2,3,4,5]

得到一个RangeError: Maximum call stack size exceeded例外。
Alejandro Cotilla

1
好答案。这正是我所需要的。
安德烈斯·菲利普

20
var s = 'MyLongString:StringIWant;';
/:([^;]+);/.exec(s)[1]; // StringIWant

1
目的是什么; 在[^;]
Jaakko Karhu

2
转换为:“ /”启动模式。将“:”与“ []”匹配为“ ^;”的任何内容 不要反复使用分号“ +”,然后找到“;” 以分号和“ /”结尾的模式。
DeveloperWeeks

15

我喜欢这种方法:

var str = 'MyLongString:StringIWant;';
var tmpStr  = str.match(":(.*);");
var newStr = tmpStr[1];
//newStr now contains 'StringIWant'

我在SharePoint 2013 Webpart中对此进行了测试,并且如果将来对任何人有帮助的话,都可以很好地工作!
Shane Gib。

3
如果所需的字符串在“(”和“)”之间,则此方法可能不起作用
bravokeyl 18-2-18

4

我使用@tsds方式,但仅使用split功能。

var str = 'one:two;three';    
str.split(':')[1].split(';')[0] // returns 'two'

温馨提示:如果therre在访问数组索引为'1'的字符串中不为“:”,则会抛出错误!str.split(':')[1]

因此,如果存在不确定性,@ tsds方式会更安全

str.split(':').pop().split(';')[0]

4
function substringBetween(s, a, b) {
    var p = s.indexOf(a) + a.length;
    return s.substring(p, s.indexOf(b, p));
}

// substringBetween('MyLongString:StringIWant;', ':', ';') -> StringIWant
// substringBetween('MyLongString:StringIWant;;', ':', ';') -> StringIWant
// substringBetween('MyLongString:StringIWant;:StringIDontWant;', ':', ';') -> StringIWant

对于两个字符之间的字符串,这是一个很好的解决方案
Phani Shashank

3

您可以使用更高阶的函数来返回提取器的“已编译”版本,这样可以更快。

使用正则表达式,并在关闭时编译一次正则表达式,Javascript的匹配项将返回所有匹配项。

这样,我们仅需删除用作标记的内容(即:){{,就可以在切片中使用字符串长度了。

function extract([beg, end]) {
    const matcher = new RegExp(`${beg}(.*?)${end}`,'gm');
    const normalise = (str) => str.slice(beg.length,end.length*-1);
    return function(str) {
        return str.match(matcher).map(normalise);
    }
}

编译一次并多次使用...

const stringExtractor = extract(['{','}']);
const stuffIneed = stringExtractor('this {is} some {text} that can be {extracted} with a {reusable} function');
// Outputs: [ 'is', 'text', 'extracted', 'reusable' ]

还是一次性使用...

const stuffIneed = extract(['{','}'])('this {is} some {text} that can be {extracted} with a {reusable} function');
// Outputs: [ 'is', 'text', 'extracted', 'reusable' ]

还要看一下Javascript的replace函数,但是要使用一个函数作为替换参数(例如,如果您正在使用小型模板引擎(字符串插值),则可以这样做... lodash.get可能对获取想要的值也很有帮助。用。。。来代替 ? ...

我的回答太长,但可能会对某人有所帮助!


2

您也可以使用此...

function extractText(str,delimiter){
  if (str && delimiter){
    var firstIndex = str.indexOf(delimiter)+1;
    var lastIndex = str.lastIndexOf(delimiter);
    str = str.substring(firstIndex,lastIndex);
  }
  return str;
}


var quotes = document.getElementById("quotes");

// &#34 - represents quotation mark in HTML
<div>


  <div>
  
    <span id="at">
      My string is @between@ the "at" sign
    </span>
    <button onclick="document.getElementById('at').innerText = extractText(document.getElementById('at').innerText,'@')">Click</button>
  
  </div>
  
  <div>
    <span id="quotes">
      My string is "between" quotes chars
    </span>
    <button onclick="document.getElementById('quotes').innerText = extractText(document.getElementById('quotes').innerText,'&#34')">Click</button>
  
  </div>

</div>


2

在子字符串之间获取字符串(包含多个1个字符)

function substrInBetween(whole_str, str1, str2){
  strlength1 = str1.length;
  return whole_str.substring(
                whole_str.indexOf(str1) + strlength1, 
                whole_str.indexOf(str2)
               );

   }

请注意,我使用indexOf()代替,lastIndexOf()因此它将检查这些字符串的首次出现


尼斯和非常可读的功能。但是strlength1变量的目的是什么?该值应内联使用。同样也不清楚您使用的是哪种样式strlength1-没有风格whole_str-蛇皮套
鲍里斯


1

使用jQuery

get_between <- function(str, first_character, last_character) {
    new_str = str.match(first_character + "(.*)" + last_character)[1].trim()
    return(new_str)
    }

my_string = 'and the thing that ! on the @ with the ^^ goes now' 

用法

get_between(my_string, 'that', 'now')

结果

"! on the @ with the ^^ goes

1

我制作的一个小函数可以捕获之间的字符串,并且可以(可选)跳过多个匹配的单词以捕获特定的索引。

另外,设置startfalse将使用字符串的开头,设置endfalse将使用字符串的结尾。

设置pos1start要使用的文本的位置,1将使用第一个出现的start

pos2与的功能相同pos1,但对于end1end仅使用after之后的第一次start出现,endbefore的出现会start被忽略。

function getStringBetween(str, start=false, end=false, pos1=1, pos2=1){
  var newPos1 = 0;
  var newPos2 = str.length;

  if(start){
    var loops = pos1;
    var i = 0;
    while(loops > 0){
      if(i > str.length){
        break;
      }else if(str[i] == start[0]){
        var found = 0;
        for(var p = 0; p < start.length; p++){
          if(str[i+p] == start[p]){
            found++;
          }
        }
        if(found >= start.length){
          newPos1 = i + start.length;
          loops--;
        }
      }
      i++;
    }
  }

  if(end){
    var loops = pos2;
    var i = newPos1;
    while(loops > 0){
      if(i > str.length){
        break;
      }else if(str[i] == end[0]){
        var found = 0;
        for(var p = 0; p < end.length; p++){
          if(str[i+p] == end[p]){
            found++;
          }
        }
        if(found >= end.length){
          newPos2 = i;
          loops--;
        }
      }
      i++;
    }
  }

  var result = '';
  for(var i = newPos1; i < newPos2; i++){
    result += str[i];
  }
  return result;
}

1

这可能是解决方案

var str = 'RACK NO:Stock;PRODUCT TYPE:Stock Sale;PART N0:0035719061;INDEX NO:21A627 042;PART NAME:SPRING;';  
var newstr = str.split(':')[1].split(';')[0]; // return value as 'Stock'

console.log('stringvalue',newstr)
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.