JavaScript 문자열에서 숫자를 추출하려면 어떻게 해야 합니까?
JavaScript에 문자열이 있습니다(예:#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"
이 답변이 어떤 이유에서인지 인기를 끌었기 때문에, 여기에 보너스가 있습니다: regex generator.
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>
다음 작업을 수행해야 합니다.
var txt = "#div-name-1234-characteristic:561613213213";
var numb = txt.match(/\d/g);
numb = numb.join("");
alert (numb);
결과
1234561613213213
이 정규 표현이 목적에 부합할 것 같습니다.
var num = txt.replace(/[^0-9]/g,'');
어디에txt
당신의 문자열입니다.
기본적으로 숫자가 아닌 모든 것을 뜯어냅니다.
이것으로도 같은 것을 달성할 수 있다고 생각합니다.
var num = txt.replace(/\D/g,'');
다음을 시도해 보십시오.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, ''));
일치 기능을 사용합니다.
var thenum = "0a1bbb2".match(/\d+$/)[0];
console.log(thenum);
그리고 이것은 통화와 포맷으로 가격을 추출하는 단편이다.
var price = "£1,739.12";
parseFloat(price.replace( /[^\d\.]*/g, '')); // 1739.12
위의 모든 조합을 이 코드와 조합하여 실행해 보았습니다.이 문자열에서는 유일하게 동작했습니다.->(12) 3456-7890
var str="(12) 3456-7890";
str.replace( /\D+/g, '');
결과: "1234567890"
옵스: 그런 문자열은 공개되지 않을 것이라는 것을 알지만, 어쨌든 솔루션이 더 완벽하기 때문에 더 낫습니다.
훌륭한 해석법을 사용할 수 있다Int 방식
선두 자리수를 숫자로 변환합니다.
parseInt("-10px");
// will give you -10
정규식을 사용하여 문자열에서 숫자를 추출할 수 있습니다.
let string = "xxfdx25y93.34xxd73";
let res = string.replace(/\D/g, "");
console.log(res);
출력: 25933473
vanilla javascript 함수로 포장합니다.
function onlyNumbers(text){
return text.replace(/\D/g, "");
}
다음과 같은 문자열의 경우#box2
이 동작은 다음과 같습니다.
var thenum = thestring.replace(/^.*?(\d+).*/,'$1');
jsFiddle:
function justNumbers(string)
{
var numsStr = string.replace(/[^0-9]/g,'');
return parseInt(numsStr);
}
console.log(justNumbers('abcdefg12hijklmnop'));
이런 기능을 할 수 있습니다.
function justNumbers(string)
{
var numsStr = string.replace(/[^0-9]/g,'');
return parseInt(numsStr);
}
기억: 번호 앞에 0이 있으면 int는 0이 되지 않습니다.
$6,694.20 정도의 가격에서 숫자를 해석하고 싶은 경우.
다음과 같이 할 수 있습니다.
parseFloat('$6,694.20'.replace( /^\D|,+/g, ''))
또는 기능을 통해:
function parsePrice(value) {
return parseFloat(value.replace( /^\D|,+/g, ''))
}
parsePrice('$6,694.20') // 6694.2
정규 표현을 사용할 수 있습니다.
var txt="some text 2";
var numb = txt.match(/\d/g);
alert (numb);
그러면 2번 경보가 울립니다.
추출된 숫자의 점을 보존해야 하는 경우:
var some = '65,87 EUR';
var number = some.replace(",",".").replace(/[^0-9&.]/g,'');
console.log(number); // returns 65.87
언더스코어 문자열 라이브러리를 다음과 같이 사용할 수 있습니다.
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);
}
정규 표현을 사용하여 문자열에서 숫자를 가져오는 방법. 예를 들어 다음과 같습니다.
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 someStr = 'abc'; // add 123 to string to see inverse
var thenum = someStr.match(/\d+/);
if (thenum != null )
{
console.log(thenum[0]);
}
else
{
console.log('no number');
}
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
문자열에서 int를 반환하려면 다음 코드를 수행합니다.숫자가 아닌 모든 문자를 삭제하고 정수를 반환합니다.
Number("strin[g]3".replace(/\D+/g, ""))
다음 한 줄 코드를 사용하여 오류 없이 문자열의 첫 번째 숫자를 가져옵니다.
var myInt = parseInt(myString.replace(/^[^0-9]+/, ''), 10);
아래 JavaScripts를 확인하세요.그곳에서는 숫자만 얻을 수 있습니다.
var txt = "abc1234char5678#!9";
var str = txt.match(/\d+/g, "")+'';
var s = str.split(',').join('');
alert(Number(s));
output :출: :1234567789
let str = "Total Work Duration: 189.56 Hrs.Present: 23.5 Absent: 2";
/* The provided regex globally matches the character "." and a digit from the string */
let numArr = str.match(/[\d\.]+/g)
/* It returns an array [189.56, ., 23.5, 2], and uses the filter function to remove the '.' */
numArr = numArr.filter(n => n != '.')
console.log(numArr)
이 답변에는 대부분의 시나리오가 포함됩니다.사용자가 전화번호를 복사하여 붙여넣으려고 하면 이 상황을 극복할 수 있습니다.
$('#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'))
});
(/\d+/g)"를 추가해야 합니다.이 경우 숫자가 아닌 텍스트는 모두 삭제되지만 이 시점에서는 문자열이 됩니다.일치하는 변수와 "parseInt"를 생성하는 경우 새 변수를 배열 값으로 설정할 수 있습니다.다음으로 동작의 예를 제시하겠습니다.
var color = $( this ).css( "background-color" );
var r = parseInt(color.match(/\d+/g)[0]);
var g = parseInt(color.match(/\d+/g)[1]);
var b = parseInt(color.match(/\d+/g)[2]);
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)/');
프로젝트 중 하나에서 문자열에서 다음과 같은 평가값을 얻어야 했습니다.
let text = '#xbox2'
let num = text.trim().
split('').
map(num => Number(num)).
filter(x => Number.isInteger(x)
)
정규식 없이 작성되다
// Without Regex
function extractNumber(string) {
let numArray = string.split('').map(item => {
if (typeof +item === 'number' && !isNaN(+item)) return +item
})
return +numArray.join('')
}
extractNumber('@1200milion$') // 1200
언급URL : https://stackoverflow.com/questions/10003683/how-can-i-extract-a-number-from-a-string-in-javascript
'programing' 카테고리의 다른 글
Vuex 모듈이 작동하지 않는 이유는 무엇입니까?[vuex] 알 수 없는 변환 유형: moduleName/mutation (0) | 2022.09.29 |
---|---|
NumPy bool 배열의 참 요소 수를 계산하는 방법 (0) | 2022.09.29 |
413 요구 엔티티가 너무 크다 - 파일 업로드 문제 (0) | 2022.09.29 |
Angular에서 활성 경로를 결정하려면 어떻게 해야 합니까? (0) | 2022.09.29 |
조인된 테이블에 LIMIT 1이 있는 MySQL JOIN (0) | 2022.09.29 |