Витягнути ("отримати") число з рядка


354

У мене є рядок у JavaScript, як `# box2 ', і я просто хочу' 2 'від нього.

Спробував:

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

Він все ще повертає # box2 у попередженні, як я можу змусити його працювати?

Він повинен вміщувати будь-який номер довжини, прикріплений на кінці.


1
ви можете просто так зробити. це буде добре працювати. var thestring = $ (це) .attr ('href'); var thenum = parsefloat (нитка); оповіщення (thenum);
Вівек Шукла

1
цей код добре працює для мене, але для одного випадку у мене є рядок "2,5 / миля", і я хочу витягнути 2,5 з цього. Наведений вище код дає мені 25 замість 2,5
Bijay Singh

Відповіді:


578

Для цього конкретного прикладу,

 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>


15
-1, "#box2_col3".replace( /^\D+/g, '')повинно було показати 2, ні 2_col3.
Шиплу Мокаддім

2
@ shiplu.mokadd.im: Я не бачу жодних посилань на #box2_col3це питання.
georg

1
Так, немає посилання на #box2_col3. Але дивіться використовуваний регулярний вираз OP ( \w)(.+$)), який чітко вказує, що після номера є інші символи.
Шиплу Мокаддім

3
у такому випадку ваша модель також виходить з ладу, якщо до кінця є номер.
Шиплу Мокаддім

2
Ви можете зробити replaceроботу з провідними номерами, використовуючи:, theString.replace(/^.*\D+/g, '');але рішення shiplu.mokadd.im краще.
LandonSchropp

225

Спробуйте зробити наступне:

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

результат

1234561613213213

1
приємна відповідь, але що робити, якщо я хочу набір цифр окремо. тобто 1234, 5616133 ...
Амар Сінгх

Або parseInt(txt.match(/\d/g).join(''), 10)
однолінійний

" $ 20.0 ".match(/\d/g).join('') => "200" (просто кажу)
vsync

90

Я думаю, що цей регулярний вираз послужить вашим цілям:

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

Де txtваша струна.

Це в основному вириває все, що не є цифрою.

Я думаю, що ви можете досягти того ж, використовуючи і це:

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

1
/[^0-9]/g+1 для читабельності. Також використовується з більшістю відповідей тут: stackoverflow.com/q/1862130/1066234
Кай Ноак

58

Спробуйте наступне: 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, ''));


2
Це краще, ніж прийнята відповідь, оскільки вона замінює всі не цифри в усьому світі, а btw /[^0-9]/gможна замінити на /[^\d]/g.
CPHPython

52

Використання функції відповідності.

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

jsfiddle


1
Також ви можете додати Unary '+', щоб зробити його цілим var ondaum = + thestring.match (/ \ d + $ /) [0];
Сергій Онищенко

Я думаю, це не працює для> одноцифрових чисел? (Я розумію, що питання
Фелікс,

@nissemand Dont вгадати . Спробуйте самі. Навіть ви не бачили скрипки.
Шиплу Мокаддім

Люблю це. Найпростіший спосіб витягнути число в змінну без дотику або змінити елемент. Я би вдячний комбо з кожним за безліч збігів всередині рядка. тобто рядок 12a55 повідомляє останнє число, а не все.
м3нда

1
@YevgeniyAfanasyev це не повинно. Перевірте оригінальне запитання. Особливо останній рядок. Номер повинен бути в кінці.
Шиплу Мокаддім

33

Спробував усі комбінації, процитовані вище, з цим Кодексом, і він працював, був єдиним, хто працював над цим рядком ->(12) 3456-7890

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

Результат: "1234567890"

Obs: я знаю, що така рядок не буде на attr, але як би там не було, рішення краще, тому що воно є більш повним.


Я думаю, що краще, str.match(/\d+/g).map(Number)це поверне масив
Артем Бернацький

33

І це фрагмент, який витягує ціни з валютою та форматуванням:

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

13

ви можете використовувати чудовий метод parseInt

він перетворить провідні цифри в число

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

18
це працює лише тоді, коли число знаходиться на початку рядка
Russj

2
його повернення NaN
Ахмед Сиєд


4

Можна використовувати регулярне вираження.

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

Це сповістить 2.


4
-1 кілька цифр не буде зафіксовано і для використання масиву в сповіщенні
Shiplu Mokaddim

4

З допомогою регулярних виразів , як отримати число з рядка, наприклад:

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


5
java! == javascript - substituAll не існує в стандартному javascript. Лише деякі бібліотеки, такі як jQuery, мають цей метод. Надалі слід уточнити.
Леві Робертс

3

Ви можете використовувати бібліотеку рядків підкреслення наступним чином

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

_(href).strRight(common)

Результатом буде: 1

Див.: https://github.com/epeli/underscore.string

DEMO:
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);

}

3

Ось соль. що перевіряє відсутність даних

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

Використовуйте цей однорядковий код, щоб отримати перше число в рядку без помилок:

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

2

будь ласка, перевірте нижче javaScripts, там ви можете отримати лише номер

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

вихід: 1234567789


2

Ви можете витягнути числа з рядка, використовуючи вираз регулярного вираження:

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

вихід: 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

Оголошення пояснення. Наприклад, для чого ви використовуєте саме цей регулярний вираз.
менталург

1

Ця відповідь охопить більшу частину сценарію. Я можу зіткнутися з цією ситуацією, коли користувач намагається скопіювати вставити номер телефону

  $('#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, тому я використав заміну

  $('#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();

}

Ви можете зробити це так, а потім викликати функцію, де потрібно, за допомогою параметра.

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

0

Ви можете виконувати подібну функцію

function justNumbers(string) 
    {
        var numsStr = string.replace(/[^0-9]/g,'');
        return parseInt(numsStr);
    }
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.