Estrai ("ottieni") un numero da una stringa


355

Ho una stringa in javascript come `# box2 'e voglio solo il' 2 'da esso.

Provato:

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

Restituisce ancora # box2 nell'avviso, come posso farlo funzionare?

Deve contenere qualsiasi numero di lunghezza allegato all'estremità.


1
puoi semplicemente fare così. funzionerà bene. var thestring = $ (this) .attr ('href'); var thenum = parsefloat (thestring); alert (theNum);
Vivek Shukla,

1
questo codice funziona bene per me, ma per un caso, ho una stringa '2.5 / mile' e voglio estrarre 2.5 da questo. Il codice sopra mi dà 25 invece di 2.5
Bijay Singh,

Risposte:


578

Per questo esempio specifico,

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

nel caso generale:

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

Poiché questa risposta ha guadagnato popolarità per qualche motivo, ecco un bonus: generatore di 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>


15
-1, "#box2_col3".replace( /^\D+/g, '')avrebbe dovuto mostrare 2, no 2_col3.
Shiplu Mokaddim

2
@ shiplu.mokadd.im: non vedo alcun riferimento a #box2_col3nella domanda.
Georg

1
Sì, non vi è alcun riferimento a #box2_col3. Ma vedi l'OP regex usato ( \w)(.+$)) che indica chiaramente che ci sono altri caratteri dopo il numero.
Shiplu Mokaddim

3
in quel caso il tuo schema fallisce anche se c'è un numero prima della fine.
Shiplu Mokaddim

2
Puoi replacelavorare con i numeri principali usando theString.replace(/^.*\D+/g, '');:, ma la soluzione di shiplu.mokadd.im è migliore.
LandonSchropp

225

Dovresti provare quanto segue:

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

risultato

1234561613213213

1
bella risposta, ma cosa succede se voglio l'insieme dei numeri separatamente. cioè 1234, 5616133 ...
Amar Singh il

O one-liner + parsing to integer:parseInt(txt.match(/\d/g).join(''), 10)
Lukas Liesis

" $ 20.0 ".match(/\d/g).join('') => "200" (solo per dire)
vsync

91

Penso che questa espressione regolare servirà al tuo scopo:

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

Dov'è la txttua stringa.

Fondamentalmente strappa tutto ciò che non è una cifra.

Penso che puoi ottenere la stessa cosa anche usando questo:

var num = txt.replace(/\D/g,'');

1
/[^0-9]/g+1 per leggibilità. Utilizzato anche con la maggior parte delle risposte qui: stackoverflow.com/q/1862130/1066234
Kai Noack

58

Prova quanto segue: string.replace(/[^0-9]/g, '');questo eliminerà tutti i caratteri non numerici, lasciando solo le cifre nella stringa

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


2
Questo è meglio della risposta accettata, poiché sostituisce tutti i non numeri a livello globale e tra l'altro, /[^0-9]/gpuò essere sostituito con /[^\d]/g.
CPHPython

52

Usando la funzione match.

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

jsfiddle


1
Inoltre puoi aggiungere unario '+' per renderlo intero var thenum = + thestring.match (/ \ d + $ /) [0];
Sergey Onishchenko,

Immagino che questo non funzioni con numeri> 1 cifra? (Capisco che la domanda era per numeri a 1 cifra, ma sto guardando numeri possibili> 10.)
Felix

@nissemand Non indovinare . Mettiti alla prova. Anche tu non hai visto il violino.
Shiplu Mokaddim,

Ama questo. Un modo più semplice per estrarre il numero in una variabile senza toccare o modificare l'elemento. Gradirei una combinazione con ognuna per molteplici coincidenze all'interno di una stringa. cioè la stringa 12a55 riporta l'ultimo numero, non tutto.
m3nda,

1
@YevgeniyAfanasyev non dovrebbe. Controlla la domanda originale. Specialmente l'ultima riga. Il numero dovrebbe essere alla fine.
Shiplu Mokaddim,

33

Ho provato tutte le combinazioni sopra citate con questo codice e l'ho fatto funzionare, è stata l'unica che ha funzionato su quella stringa ->(12) 3456-7890

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

Risultato: "1234567890"

Obs: so che una stringa del genere non sarà sull'attr ma, comunque, la soluzione è migliore, perché è più completa.


penso che meglio sarà str.match(/\d+/g).map(Number)che restituirà un array
Artem Bernatskyi il

33

E questo è uno snippet che estrae i prezzi con valuta e formattazione:

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

13

puoi usare un ottimo metodo di analisi

convertirà le cifre iniziali in un numero

parseInt("-10px");
// will give you -10

18
funziona solo quando il numero è all'inizio della stringa
Russj,

2
il suo ritorno NaN
Ahmed Syed l'


4

Puoi usare l'espressione regolare.

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

Questo avviserà 2.


4
-1 non verranno acquisite più cifre e per l'utilizzo dell'array in allerta
Shiplu Mokaddim

4

Con le espressioni regolari , come ottenere numeri da una stringa, ad esempio:

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

il risultato di myStringè " 24"

puoi vedere un esempio di questo codice in esecuzione qui: http://ideone.com/iOCf5G


5
java! == javascript - replaceAll non esiste in javascript standard. Solo alcune librerie come jQuery hanno quel metodo. In futuro, dovresti chiarire.
Levi Roberts,

3

È possibile utilizzare Underscore String Library come segue

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

_(href).strRight(common)

il risultato sarà: 1

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

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

Codice JS:

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

se hai il suffisso come segue:

href="box1az" 

Puoi usare la prossima demo:

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

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

}

3

Ecco un senso. che verifica la mancanza di dati

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

2

Utilizzare questo codice di una riga per ottenere il primo numero in una stringa senza ottenere errori:

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

2

si prega di controllare sotto javaScripts, lì è possibile ottenere solo numero

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

produzione : 1234567789


2

Puoi estrarre numeri da una stringa usando un'espressione regex:

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

uscita: 25933473


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

Ad una spiegazione. Ad esempio, perché usi questo regex.
Mentallurg,

1

Questa risposta coprirà la maggior parte dello scenario. Posso attraversare questa situazione quando l'utente tenta di copiare incollare il numero di telefono

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

Spiegazione:

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

str.match(/\d+/g)

Fornirà una matrice di stringhe come output >> ["34", "56766"]

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

join convertirà e concatenerà i dati dell'array in un'unica stringa

uscita >> "3456766"

Nel mio esempio ho bisogno dell'output come 209-356-6788, quindi ho usato sostituire

  $('#help_number').keyup(function(){
    $(this).val($(this).val().match(/\d+/g).join("").replace(/(\d{3})\-?(\d{3})\-?(\d{4})/,'$1-$2-$3'))
  });

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();

}

Puoi farlo in quel modo e quindi chiamare la funzione dove ti serve, con il parametro.

this.changeStrangeDate('/Date(1551401820000-0100)/');

0

Puoi fare una funzione come questa

function justNumbers(string) 
    {
        var numsStr = string.replace(/[^0-9]/g,'');
        return parseInt(numsStr);
    }
Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.