`# box2 '와 같은 자바 스크립트에 문자열이 있으며'2 '를 원합니다.
시도 :
var thestring = $(this).attr('href');
var thenum = thestring.replace( /(^.+)(\w\d+\w)(.+$)/i,'$2');
alert(thenum);
여전히 경고에서 # box2를 반환합니다. 어떻게 작동합니까?
끝에 부착 된 길이 번호를 수용해야합니다.
`# box2 '와 같은 자바 스크립트에 문자열이 있으며'2 '를 원합니다.
시도 :
var thestring = $(this).attr('href');
var thenum = thestring.replace( /(^.+)(\w\d+\w)(.+$)/i,'$2');
alert(thenum);
여전히 경고에서 # box2를 반환합니다. 어떻게 작동합니까?
끝에 부착 된 길이 번호를 수용해야합니다.
답변:
이 특정 예에서는
var thenum = thestring.replace( /^\D+/g, ''); // replace all leading non-digits with nothing
일반적인 경우 :
thenum = "foo3bar5".match(/\d+/)[0] // "3"
이 답변이 어떤 이유로 인기를 얻었으므로 여기에 보너스가 있습니다 : 정규식 생성기.
function getre(str, num) {
if(str === num) return 'nice try';
var res = [/^\D+/g,/\D+$/g,/^\D+|\D+$/g,/\D+/g,/\D.*/g, /.*\D/g,/^\D+|\D.*$/g,/.*\D(?=\d)|\D+$/g];
for(var i = 0; i < res.length; i++)
if(str.replace(res[i], '') === num)
return 'num = str.replace(/' + res[i].source + '/g, "")';
return 'no idea';
};
function update() {
$ = function(x) { return document.getElementById(x) };
var re = getre($('str').value, $('num').value);
$('re').innerHTML = 'Numex speaks: <code>' + re + '</code>';
}
<p>Hi, I'm Numex, the Number Extractor Oracle.
<p>What is your string? <input id="str" value="42abc"></p>
<p>What number do you want to extract? <input id="num" value="42"></p>
<p><button onclick="update()">Insert Coin</button></p>
<p id="re"></p>
"#box2_col3".replace( /^\D+/g, '')
은 2
아니 어야합니다 2_col3
.
#box2_col3
질문에 대한 언급이 없습니다 .
#box2_col3
.에 대한 참조가 없습니다 . 그러나 \w)(.+$)
숫자 뒤에 다른 문자가 있음을 분명히 나타내는 정규식 OP ( )를 참조하십시오 .
replace
을 사용하여 선행 숫자로 작업 할 수 theString.replace(/^.*\D+/g, '');
있지만 shiplu.mokadd.im의 솔루션이 더 좋습니다.
다음을 시도해야합니다.
var txt = "#div-name-1234-characteristic:561613213213";
var numb = txt.match(/\d/g);
numb = numb.join("");
alert (numb);
결과
1234561613213213
parseInt(txt.match(/\d/g).join(''), 10)
" $ 20.0 ".match(/\d/g).join('')
=> "200"(단지 말함)
나는이 정규 표현이 당신의 목적에 도움이 될 것이라고 생각합니다 :
var num = txt.replace(/[^0-9]/g,'');
txt
당신의 줄은 어디에 있습니까 ?
기본적으로 숫자가 아닌 것을 버립니다.
나는 이것을 사용하여 동일한 것을 달성 할 수 있다고 생각합니다.
var num = txt.replace(/\D/g,'');
/[^0-9]/g
가독성 +1 또한 여기에 대부분의 답변과 함께 사용됩니다 : stackoverflow.com/q/1862130/1066234
다음을 시도하십시오. string.replace(/[^0-9]/g, '');
이것은 숫자가 아닌 모든 문자를 삭제하고 문자열에는 숫자 만 남겨 둡니다.
function retnum(str) {
var num = str.replace(/[^0-9]/g, '');
return parseInt(num,10);
}
console.log('abca12bc45qw'.replace(/[^0-9]/g, ''));
console.log('#box2'.replace(/[^0-9]/g, ''));
/[^0-9]/g
를로 대체 할 수 있기 때문에 허용되는 대답보다 낫습니다 /[^\d]/g
.
이 코드와 함께 위에서 인용 한 모든 조합을 시도 하고 작동 시켰습니다. 유일한 문자열에서 작동했습니다->(12) 3456-7890
var str="(12) 3456-7890";
str.replace( /\D+/g, '');
결과: "1234567890"
Obs : 그런 문자열이 attr에 있지는 않지만 해결책은 더 완벽하기 때문에 더 좋습니다.
str.match(/\d+/g).map(Number)
배열을 반환하는 것이 더 나을 것이라고 생각합니다
와 같은 문자열의 경우 다음과 같이 #box2
작동합니다.
var thenum = thestring.replace(/^.*?(\d+).*/,'$1');
jsFiddle :
정규식을 사용할 수 있습니다.
var txt="some text 2";
var numb = txt.match(/\d/g);
alert (numb);
경고 2입니다.
정규 표현식을 사용하면 문자열에서 숫자를 얻는 방법 (예 :
String myString = "my 2 first gifts were made by my 4 brothers";
myString = myString .replaceAll("\\D+","");
System.out.println("myString : " + myString);
결과 myString
는 " 24
"
이 실행 코드의 예는 여기에서 볼 수 있습니다. http://ideone.com/iOCf5G
밑줄 문자열 라이브러리를 다음과 같이 사용할 수 있습니다
var common="#box"
var href="#box1"
_(href).strRight(common)
결과는 다음과 같습니다. 1
참조 : https://github.com/epeli/underscore.string
데모 :
http://jsfiddle.net/abdennour/Vyqtt/
HTML 코드 :
<p>
<a href="#box1" >img1</a>
<a href="#box2" >img2</a>
<a href="#box3" >img3</a>
<a href="#box4" >img4</a>
</p>
<div style="font-size:30px"></div>
JS 코드 :
var comm="#box"
$('a').click(function(){
$('div').html(_($(this).attr('href')).strRight(comm))})
다음과 같이 접미사가있는 경우 :
href="box1az"
다음 데모를 사용할 수 있습니다.
http://jsfiddle.net/abdennour/Vyqtt/1/
function retrieveNumber(all,prefix,suffix){
var left=_(all).strRight(prefix);
return _(left).strLeft(suffix);
}
var elValue = "-12,erer3 4,-990.234sdsd";
var isNegetive = false;
if(elValue.indexOf("-")==0) isNegetive=true;
elValue = elValue.replace( /[^\d\.]*/g, '');
elValue = isNaN(Number(elValue)) ? 0 : Number(elValue);
if(isNegetive) elValue = 0 - elValue;
alert(elValue); //-1234990.234
이 답변은 대부분의 시나리오를 다룰 것입니다. 사용자가 전화 번호를 붙여 넣으려고 할 때이 상황에서
$('#help_number').keyup(function(){
$(this).val().match(/\d+/g).join("")
});
설명:
str= "34%^gd 5-67 6-6ds"
str.match(/\d+/g)
출력으로 문자열 배열을 제공합니다 >> ""34 ","56766 "]
str.match(/\d+/g).join("")
join은 배열 데이터를 단일 문자열로 변환하고 연결합니다.
출력 >> "3456766"
내 예에서는 209-356-6788로 출력이 필요하므로 replace를 사용했습니다.
$('#help_number').keyup(function(){
$(this).val($(this).val().match(/\d+/g).join("").replace(/(\d{3})\-?(\d{3})\-?(\d{4})/,'$1-$2-$3'))
});
changeStrangeDate(dateString: string) {
var sum = 0;
var numbers = dateString.match(/\d+/g);
if (numbers.length > 1) {
numbers.forEach(element => {
sum += parseInt(element);
}
);
}
console.log(new Date(sum).toDateString());
return new Date(sum).toUTCString();
}
그렇게하면 매개 변수를 사용하여 필요한 곳에서 함수를 호출 할 수 있습니다.
this.changeStrangeDate('/Date(1551401820000-0100)/');