794 Stimmen

Zählt die Anzahl der Vorkommen eines Zeichens in einer Zeichenkette in Javascript

Ich muss die Anzahl der Vorkommen eines Zeichens in einer Zeichenkette zählen.

Nehmen wir zum Beispiel an, meine Zeichenkette enthält:

var mainStr = "str1,str2,str3,str4";

Ich möchte die Anzahl der Kommas ermitteln , Zeichen, also 3, und die Anzahl der einzelnen Zeichenfolgen nach der Trennung durch Komma, also 4.

Außerdem muss ich überprüfen, dass jede der Zeichenketten, d. h. str1 oder str2 oder str3 oder str4, nicht mehr als, sagen wir, 15 Zeichen umfassen sollte.

1voto

Marc K. Punkte 59

Ich verwende Node.js v.6.0.0 und die schnellste ist die mit Index (die 3. Methode in Lo Sauers Antwort).

Die zweite ist:

function count(s, c) {
  var n = 0;
  for (let x of s) {
    if (x == c)
      n++;
  }
  return n;
}

0voto

Gere Punkte 1994

Meine Lösung:

function countOcurrences(str, value){
   var regExp = new RegExp(value, "gi");
   return str.match(regExp) ? str.match(regExp).length : 0;  
}

0voto

Nitin . Punkte 754
var a = "acvbasbb";
var b= {};
for (let i=0;i<a.length;i++){
    if((a.match(new RegExp(a[i], "g"))).length > 1){
        b[a[i]]=(a.match(new RegExp(a[i], "g"))).length;
    }
}
console.log(b);

In Javascript können Sie obigen Code verwenden, um das Vorkommen eines Zeichens in einer Zeichenfolge zu erhalten.

0voto

Jack G Punkte 3797

Ich glaube, Sie werden feststellen, dass die folgende Lösung sehr kurz und schnell ist, mit sehr langen Zeichenfolgen arbeiten kann, die Suche nach mehreren Zeichen unterstützt, fehlerfrei ist und leere Zeichenfolgen verarbeiten kann.

function substring_count(source_str, search_str, index) {
    source_str += "", search_str += "";
    var count = -1, index_inc = Math.max(search_str.length, 1);
    index = (+index || 0) - index_inc;
    do {
        ++count;
        index = source_str.indexOf(search_str, index + index_inc);
    } while (~index);
    return count;
}

Beispiel für die Verwendung:

console.log(substring_count("Lorem ipsum dolar un sit amet.", "m "))

function substring_count(source_str, search_str, index) {
    source_str += "", search_str += "";
    var count = -1, index_inc = Math.max(search_str.length, 1);
    index = (+index || 0) - index_inc;
    do {
        ++count;
        index = source_str.indexOf(search_str, index + index_inc);
    } while (~index);
    return count;
}

Der obige Code behebt den großen Performance-Fehler in Jakub Wawszczyk's Code, dass der Code weiterhin nach einer Übereinstimmung sucht, auch wenn indexOf sagt, dass es keine gibt, und seine Version selbst funktioniert nicht, weil er vergessen hat, die Eingabeparameter der Funktion anzugeben.

0voto

Michal Punkte 4378

Meine Lösung mit ramda js:

const testString = 'somestringtotest'

const countLetters = R.compose(
  R.map(R.length),
  R.groupBy(R.identity),
  R.split('')
)

countLetters(testString)

Verbindung zur REPL.

CodeJaeger.com

CodeJaeger ist eine Gemeinschaft für Programmierer, die täglich Hilfe erhalten..
Wir haben viele Inhalte, und Sie können auch Ihre eigenen Fragen stellen oder die Fragen anderer Leute lösen.

Powered by:

X