Extraia ("obtenha") um número de uma string

355

Eu tenho uma string em javascript como `# box2 'e só quero o' 2 '.

Tentou:

var thestring = $(this).attr('href');
var thenum = thestring.replace( /(^.+)(\w\d+\w)(.+$)/i,'$2');
alert(thenum);

Ele ainda retorna # box2 no alerta, como posso fazê-lo funcionar?

Ele precisa acomodar qualquer número de comprimento anexado no final.

user1022585
fonte
11
você pode simplesmente fazer assim. funcionará bem. var thestring = $ (this) .attr ('href'); var thenum = parsefloat (thestring); alerta (thenum);
Vivek Shukla
11
esse código funciona bem para mim, mas, para um caso, tenho uma string '2.5 / mile' e quero extrair 2.5 disso. O código acima me dá 25 em vez de 2.5 #
Bijay Singh
11
Relacionados: stackoverflow.com/q/1862130/1066234
Kai Noack

Respostas:

578

Para este exemplo específico,

 var thenum = thestring.replace( /^\D+/g, ''); // replace all leading non-digits with nothing

no caso geral:

 thenum = "foo3bar5".match(/\d+/)[0] // "3"

Como essa resposta ganhou popularidade por algum motivo, aqui está um bônus: gerador de regex.

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>

georg
fonte
15
-1, "#box2_col3".replace( /^\D+/g, '')deveria ter mostrado 2, não 2_col3.
Shiplu Mokaddim 04/04/12
2
@ shiplu.mokadd.im: Não vejo nenhuma referência #box2_col3na pergunta.
amigos estão dizendo sobre georg
11
Sim, não há referência de #box2_col3. Mas veja o regex OP used ( \w)(.+$)) que indica claramente que existem outros caracteres após o número.
Shiplu Mokaddim 04/04/12
3
nesse caso, seu padrão também falhará se houver número antes do final.
Shiplu Mokaddim 04/04/12
2
Você pode replacetrabalhar com números theString.replace(/^.*\D+/g, '');iniciais usando :, mas a solução do shiplu.mokadd.im é melhor.
LandonSchropp
225

Você deve tentar o seguinte:

var txt = "#div-name-1234-characteristic:561613213213";
var numb = txt.match(/\d/g);
numb = numb.join("");
alert (numb);​

resultado

1234561613213213
Jason Marshall
fonte
11
boa resposta, mas e se eu quiser o conjunto de números separadamente. 1234, 5616133 ...
Amar Singh
Ou one-liner + analisando para inteiro:parseInt(txt.match(/\d/g).join(''), 10)
Lukas Liesis
" $ 20.0 ".match(/\d/g).join('') => "200" (apenas dizendo)
vsync
91

Penso que esta expressão regular servirá ao seu propósito:

var num = txt.replace(/[^0-9]/g,'');

Onde txtestá sua corda?

Basicamente rasga tudo o que não é um dígito.

Eu acho que você pode conseguir a mesma coisa usando isso também:

var num = txt.replace(/\D/g,'');
Theodoros Klikas
fonte
11
/[^0-9]/g+1 para facilitar a leitura. Também é usado com a maioria das respostas aqui: stackoverflow.com/q/1862130/1066234
Kai Noack
58

Tente o seguinte: string.replace(/[^0-9]/g, '');Isso excluirá todos os caracteres que não são dígitos, deixando apenas dígitos na string

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, ''));

xbalaji
fonte
2
Isso é melhor do que a resposta aceita, uma vez que substitui todos os não números globalmente e /[^0-9]/gpode ser substituída por /[^\d]/g.
CPHPython 19/03/19
52

Usando a função de correspondência.

var thenum = thestring.match(/\d+$/)[0];
alert(thenum);

jsfiddle

Shiplu Mokaddim
fonte
11
Você também pode adicionar '+' unário para torná-lo inteiro var thenum = + thestring.match (/ \ d + $ /) [0];
Sergey Onishchenko
Eu acho que isso não funciona para números> 1 dígito? (Entendo que a pergunta era para números de 1 dígito, mas estou procurando números possíveis> 10).
Felix
@nissemand Não acho . Tente você mesmo. Mesmo você não viu o violino.
Shiplu Mokaddim
Amo isso. Uma maneira mais simples de extrair o número em uma variável sem tocar ou modificar o elemento. Eu apreciaria um combo com cada um por várias coincidências dentro de uma string. ou seja, a string 12a55 informa o último número, não todos.
M3nda
11
@YevgeniyAfanasyev não deveria. Verifique a pergunta original. Especialmente a última linha. O número deve estar no final.
Shiplu Mokaddim 29/04
33

Tentei todas as combinações citadas acima com este código e o fiz funcionar, foi a única que trabalhou nessa cadeia ->(12) 3456-7890

var str="(12) 3456-7890";
str.replace( /\D+/g, '');

Resultado: "1234567890"

Obs: eu sei que uma string como essa não estará no atributo, mas, seja como for, a solução é melhor, porque é mais completa.

Paulo Roberto Rosa
fonte
eu acho melhor será str.match(/\d+/g).map(Number)ele irá retornar um array
Artem Bernatskyi
33

E este é um trecho que extrai preços com moeda e formatação:

var price = "£1,739.12";
parseFloat(price.replace( /[^\d\.]*/g, '')); // 1739.12
Lacho Tomov
fonte
13

você pode usar o ótimo método parseInt

ele converterá os dígitos iniciais em um número

parseInt("-10px");
// will give you -10
Eugene Tiurin
fonte
18
isso só funciona quando o número está no início da string
Russj
2
seu retorno NaN
Ahmed Syed
7

Para uma sequência como #box2, isso deve funcionar:

var thenum = thestring.replace(/^.*?(\d+).*/,'$1');

jsFiddle:

icyrock.com
fonte
4

Você pode usar expressão regular.

var txt="some text 2";
var numb = txt.match(/\d/g);
alert (numb);

Isso alertará 2.

Robby Shaw
fonte
4
-1 vários dígitos não vai ser capturado e para a utilização de matriz em alerta
Shiplu Mokaddim
4

Com Expressões regulares , como obter números de uma String, por exemplo:

String myString = "my 2 first gifts were made by my 4 brothers";
myString = myString .replaceAll("\\D+","");
System.out.println("myString : " + myString);

o resultado de myStringé " 24"

você pode ver um exemplo desse código em execução aqui: http://ideone.com/iOCf5G

Jorgesys
fonte
5
java! == javascript - replaceAll não existe no javascript padrão. Somente algumas bibliotecas como o jQuery possuem esse método. No futuro, você deve esclarecer.
Levi Roberts
3

Você pode usar a Underscore String Library da seguinte maneira

var common="#box"
var href="#box1"

_(href).strRight(common)

o resultado será: 1

Consulte: https://github.com/epeli/underscore.string

DEMO:
http://jsfiddle.net/abdennour/Vyqtt/
Código 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>

Código JS:

var comm="#box"
$('a').click(function(){
  $('div').html(_($(this).attr('href')).strRight(comm))})

se você tiver o sufixo da seguinte forma:

href="box1az" 

Você pode usar a próxima demonstração:

http://jsfiddle.net/abdennour/Vyqtt/1/

function retrieveNumber(all,prefix,suffix){
 var left=_(all).strRight(prefix);
 return _(left).strLeft(suffix);

}
Abdennour TOUMI
fonte
3

Aqui está um solt. que verifica se não há dados

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');
}
Gene Bo
fonte
2

Use este código de uma linha para obter o primeiro número em uma string sem obter erros:

var myInt = parseInt(myString.replace(/^[^0-9]+/, ''), 10);
Ruslan
fonte
2

verifique abaixo javaScripts, lá você pode obter apenas um número

var txt = "abc1234char5678#!9";
var str = txt.match(/\d+/g, "")+'';
var s = str.split(',').join('');
alert(Number(s));

resultado : 1234567789

Thilina Sampath
fonte
2

Você pode extrair números de uma string usando uma expressão regex:

let string = "xxfdx25y93.34xxd73";
let res = string.replace(/\D/g, "");
console.log(res); 

saída: 25933473

Cassio Seffrin
fonte
1
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
Manoj Chavanke
fonte
Ad uma explicação. Por exemplo, por que você usa esse regex.
mentallurg 16/06/19
1

Esta resposta cobrirá a maior parte do cenário. Posso atravessar essa situação quando o usuário tenta copiar e colar o número de telefone

  $('#help_number').keyup(function(){
    $(this).val().match(/\d+/g).join("")
  });

Explicação:

str= "34%^gd 5-67 6-6ds"

str.match(/\d+/g)

Ele fornecerá uma matriz de string como saída >> ["34", "56766"]

str.match(/\d+/g).join("")

join converterá e concatenará esses dados da matriz em uma única sequência

saída >> "3456766"

No meu exemplo, eu preciso da saída como 209-356-6788, então usei replace

  $('#help_number').keyup(function(){
    $(this).val($(this).val().match(/\d+/g).join("").replace(/(\d{3})\-?(\d{3})\-?(\d{4})/,'$1-$2-$3'))
  });
Vinay Kumar
fonte
0
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();

}

Você pode fazer assim e então chamar a função onde precisar, com o parâmetro

this.changeStrangeDate('/Date(1551401820000-0100)/');
Irakli Kardava
fonte
0

Você pode fazer uma função como esta

function justNumbers(string) 
    {
        var numsStr = string.replace(/[^0-9]/g,'');
        return parseInt(numsStr);
    }
Danielle Cohen
fonte