जवाबों:
exec
एक index
संपत्ति के साथ एक वस्तु देता है :
var match = /bar/.exec("foobar");
if (match) {
console.log("match found at " + match.index);
}
और कई मैचों के लिए:
var re = /bar/g,
str = "foobarfoobar";
while ((match = re.exec(str)) != null) {
console.log("match found at " + match.index);
}
re
एक चर के रूप में, और g
संशोधक का उपयोग करके दोनों महत्वपूर्ण हैं! अन्यथा आपको एक अंतहीन लूप मिलेगा।
undefined
। jsfiddle.net/6uwn1vof/2 जो आपके जैसा खोज-जैसा उदाहरण नहीं है।
g
झंडे को हटा दें और यह काम करेगा। चूँकि match
यह स्ट्रिंग का एक कार्य है, न कि रेगेक्स जैसा exec
कि इसे स्टेटफुल नहीं किया जा सकता है , इसलिए यह केवल इसे व्यवहार करता है exec
(जैसे कि एक इंडेक्स प्रॉपर्टी है) यदि आप एक वैश्विक मैच की तलाश में नहीं हैं ... क्योंकि तब राज्य की स्थिति कोई मायने नहीं रखती है। ।
यहाँ मैं क्या लेकर आया हूँ:
// Finds starting and ending positions of quoted text
// in double or single quotes with escape char support like \" \'
var str = "this is a \"quoted\" string as you can 'read'";
var patt = /'((?:\\.|[^'])*)'|"((?:\\.|[^"])*)"/igm;
while (match = patt.exec(str)) {
console.log(match.index + ' ' + patt.lastIndex);
}
match.index + match[0].length
अंत स्थिति के लिए भी काम करता है।
match.index + match[0].length - 1
?
.slice()
और .substring()
। आपके कहने के अनुसार समावेशी अंत 1 कम होगा। (सावधान रहें कि समावेशी का मतलब आमतौर पर मैच के अंदर अंतिम चार का सूचकांक होता है, जब तक कि यह एक खाली मैच न हो जहां यह मैच से पहले 1 हो और -1
शुरुआत में खाली मैच के लिए पूरी तरह से स्ट्रिंग के बाहर हो सकता है ...)
स्ट्रिंग विधि पर developer.mozilla.org डॉक्स से .match()
:
लौटे एरे में एक अतिरिक्त इनपुट संपत्ति है, जिसमें मूल स्ट्रिंग है जिसे पार्स किया गया था। इसके अलावा, इसमें एक सूचकांक गुण है, जो स्ट्रिंग में मैच के शून्य-आधारित सूचकांक का प्रतिनिधित्व करता है ।
जब एक गैर-वैश्विक रेगेक्स (यानी, g
आपके रेगेक्स पर कोई ध्वज नहीं ) के साथ काम करते हैं, तो उसके द्वारा लौटाए गए मूल्य .match()
में एक index
संपत्ति होती है ... आपको बस इतना करना होगा।
var index = str.match(/regex/).index;
यहाँ एक उदाहरण दिखाया गया है कि यह काम कर रहा है:
var str = 'my string here';
var index = str.match(/here/).index;
alert(index); // <- 10
मैं सफलतापूर्वक IE5 के लिए यह सब तरह से परीक्षण किया है।
आप ऑब्जेक्ट की search
विधि का उपयोग कर सकते हैं String
। यह केवल पहले मैच के लिए काम करेगा, लेकिन अन्यथा आप जो वर्णन करते हैं वह करेंगे। उदाहरण के लिए:
"How are you?".search(/are/);
// 4
यहाँ हाल ही में खोजा गया एक अच्छा फीचर है, मैंने कंसोल पर यह कोशिश की और यह काम करने लगता है:
var text = "border-bottom-left-radius";
var newText = text.replace(/-/g,function(match, index){
return " " + index + " ";
});
जो लौटा: "बॉर्डर 6 बॉटम 13 ने 18 रेडियस छोड़ा"
तो ऐसा लगता है कि आप क्या देख रहे हैं।
arguments
कि स्थिति है। "दूसरा तर्क" नहीं। फ़ंक्शन तर्क "पूर्ण मिलान, Group1, group2, ...., मैच का सूचकांक, पूर्ण स्ट्रिंग के विरुद्ध मिलान"
आधुनिक ब्राउज़रों में, आप इसे string.matchAll () के साथ पूरा कर सकते हैं ।
इस दृष्टिकोण बनाम RegExp.exec()
का लाभ यह है कि यह रेगुक्स के स्टेटफुल होने पर निर्भर नहीं करता है, जैसा कि @ गंबो के उत्तर में है ।
let regexp = /bar/g;
let str = 'foobarfoobar';
let matches = [...str.matchAll(regexp)];
matches.forEach((match) => {
console.log("match found at " + match.index);
});
यह सदस्य fn स्ट्रिंग-ऑब्जेक्ट के अंदर इनपुट शब्द का, यदि कोई हो, तो 0-आधारित पदों की एक सरणी देता है
String.prototype.matching_positions = function( _word, _case_sensitive, _whole_words, _multiline )
{
/*besides '_word' param, others are flags (0|1)*/
var _match_pattern = "g"+(_case_sensitive?"i":"")+(_multiline?"m":"") ;
var _bound = _whole_words ? "\\b" : "" ;
var _re = new RegExp( _bound+_word+_bound, _match_pattern );
var _pos = [], _chunk, _index = 0 ;
while( true )
{
_chunk = _re.exec( this ) ;
if ( _chunk == null ) break ;
_pos.push( _chunk['index'] ) ;
_re.lastIndex = _chunk['index']+1 ;
}
return _pos ;
}
अब प्रयास करो
var _sentence = "What do doers want ? What do doers need ?" ;
var _word = "do" ;
console.log( _sentence.matching_positions( _word, 1, 0, 0 ) );
console.log( _sentence.matching_positions( _word, 1, 1, 0 ) );
आप नियमित अभिव्यक्तियों को भी इनपुट कर सकते हैं:
var _second = "z^2+2z-1" ;
console.log( _second.matching_positions( "[0-9]\z+", 0, 0, 0 ) );
यहाँ एक को रैखिक शब्द का स्थिति सूचकांक मिलता है।
var str = "The rain in SPAIN stays mainly in the plain";
function searchIndex(str, searchValue, isCaseSensitive) {
var modifiers = isCaseSensitive ? 'gi' : 'g';
var regExpValue = new RegExp(searchValue, modifiers);
var matches = [];
var startIndex = 0;
var arr = str.match(regExpValue);
[].forEach.call(arr, function(element) {
startIndex = str.indexOf(element, startIndex);
matches.push(startIndex++);
});
return matches;
}
console.log(searchIndex(str, 'ain', true));
str.indexOf
यहाँ केवल मैच द्वारा कब्जा किए गए पाठ की अगली घटना का पता चलता है, जो कि जरूरी नहीं है कि मैच हो। JS regex लुकहैड के साथ कैप्चर के बाहर पाठ की स्थितियों का समर्थन करता है। उदाहरण के लिए searchIndex("foobarfoobaz", "foo(?=baz)", true)
देना चाहिए [6]
, नहीं [0]
।
function trimRegex(str, regex){
return str.substr(str.match(regex).index).split('').reverse().join('').substr(str.match(regex).index).split('').reverse().join('');
}
let test = '||ab||cd||';
trimRegex(test, /[^|]/);
console.log(test); //output: ab||cd
या
function trimChar(str, trim, req){
let regex = new RegExp('[^'+trim+']');
return str.substr(str.match(regex).index).split('').reverse().join('').substr(str.match(regex).index).split('').reverse().join('');
}
let test = '||ab||cd||';
trimChar(test, '|');
console.log(test); //output: ab||cd