从字符串中提取(“获取”)一个数字

时间:2012-04-04 01:14:19

标签: javascript string numbers

我在javascript中有一个字符串,比如`#box2',我只想要它的'2'。

尝试:

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

它仍会在警报中返回#box2,我怎样才能让它工作?

它需要适应最后附加的任何长度数字。

24 个答案:

答案 0 :(得分:493)

对于这个具体的例子,

 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>

答案 1 :(得分:187)

您应该尝试以下方法:

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

结果

1234561613213213

答案 2 :(得分:60)

我认为这个正则表达式将满足您的目的:

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

txt是你的字符串。

它基本上扯掉了任何不是数字的东西。

我认为你也可以通过使用它来实现同样的目标:

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

答案 3 :(得分:52)

使用匹配功能。

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

jsfiddle

答案 4 :(得分:47)

请尝试以下操作: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, ''));

答案 5 :(得分:31)

尝试了上面引用的所有组合并使用此代码并使其正常工作,是唯一一个处理该字符串的人 - &gt; (12) 3456-7890

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

结果: "1234567890"

Obs:我知道像这样的字符串不会在attr上,但无论如何,解决方案更好,因为它更完整。

答案 6 :(得分:27)

这是一个用货币和格式提取价格的片段:

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

答案 7 :(得分:11)

你可以使用伟大的parseInt方法

它会将前导数字转换为数字

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

答案 8 :(得分:6)

对于#box2这样的字符串,这应该有效:

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

的jsfiddle:

答案 9 :(得分:5)

您可以使用正则表达式从字符串中提取数字:

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

输出:25933473

答案 10 :(得分: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

答案 11 :(得分:4)

您可以使用正则表达式。

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

这会提醒2。

答案 12 :(得分: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);

}

答案 13 :(得分:3)

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

记住:如果数字前面有零,则int不会拥有它

答案 14 :(得分:2)

如果您想从 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

答案 15 :(得分:1)

使用此单行代码获取字符串中的第一个数字而不会出现错误:

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

答案 16 :(得分:1)

如果有人需要在提取的数字中保留点:

var some = '65,87 EUR';
var number = some.replace(",",".").replace(/[^0-9&.]/g,'');
console.log(number); // returns 65.87

答案 17 :(得分:1)

您需要添加“(/ \ 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]);

答案 18 :(得分: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'))
  });

答案 19 :(得分:1)

请查看下面的javaScripts,在那里你只能获得数字

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

输出:1234567789

答案 20 :(得分:1)

这是一个解决方案。检查没有数据

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

答案 21 :(得分: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)/');

答案 22 :(得分:0)

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

答案 23 :(得分:0)

使用正则表达式从字符串中找出所有数字

enter image description here