我在 JavaScript 中有一个字符串(例如#box2
),我只想要2
它。
我试过:
var thestring = $(this).attr('href');
var thenum = thestring.replace( /(^.+)(\w\d+\w)(.+$)/i,'$2');
alert(thenum);
它仍然#box2
在警报中返回,我怎样才能让它工作?
它需要适应末尾附加的任何长度数字。
我在 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"
由于这个答案由于某种原因而广受欢迎,这里有一个好处:正则表达式生成器。
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"
Obs:我知道这样的字符串不会出现在 attr 上,但无论如何,解决方案更好,因为它更完整。
你可以使用很棒的 parseInt 方法
它将前导数字转换为数字
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);
}
请记住:如果数字前面有零,则 int 不会有它
您可以使用正则表达式。
var txt="some text 2";
var numb = txt.match(/\d/g);
alert (numb);
这将提醒 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
您可以使用下划线字符串库如下
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 some = '65,87 EUR';
var number = some.replace(",",".").replace(/[^0-9&.]/g,'');
console.log(number); // returns 65.87
使用此单行代码获取字符串中的第一个数字而不会出错:
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));
输出 :1234567789
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
这个答案将涵盖大部分情况。当用户尝试复制粘贴电话号码时,我可以遇到这种情况
$('#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'))
});
您需要添加 "(/\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]);
要从字符串返回 int,您可以执行以下代码。它删除所有非数字字符并返回整数。
Number("strin[g]3".replace(/\D+/g, ""))
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