`#box2 'のようなJavaScriptの文字列があり、そこから' 2 'が欲しいだけです。
試した:
var thestring = $(this).attr('href');
var thenum = thestring.replace( /(^.+)(\w\d+\w)(.+$)/i,'$2');
alert(thenum);
それでもアラートで#box2が返されますが、どのように機能させることができますか?
端に付けられた任意の長さの数値に対応する必要があります。
`#box2 'のようなJavaScriptの文字列があり、そこから' 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>
"#box2_col3".replace( /^\D+/g, '')
は表示されているはずであり、ではあり2
ません2_col3
。
#box2_col3
質問への参照がありません。
#box2_col3
。ただし\w)(.+$)
、番号の後に他の文字があることを明確に示す、使用されている正規表現OP()を参照してください。
replace
を使用して、先行数値を処理できますがtheString.replace(/^.*\D+/g, '');
、shiplu.mokadd.imのソリューションの方が優れています。
次のことを試してください。
var txt = "#div-name-1234-characteristic:561613213213";
var numb = txt.match(/\d/g);
numb = numb.join("");
alert (numb);
結果
1234561613213213
parseInt(txt.match(/\d/g).join(''), 10)
" $ 20.0 ".match(/\d/g).join('')
=> "200"(ただ言う)
この正規表現はあなたの目的に役立つと思います:
var num = txt.replace(/[^0-9]/g,'');
txt
あなたのひもはどこですか。
基本的には、数字ではないものはすべて取り除きます。
これを使用しても同じことを達成できると思います:
var num = txt.replace(/\D/g,'');
/[^0-9]/g
読みやすくするために+1。また、ここのほとんどの回答で使用されます:stackoverflow.com/q/1862130/1066234
以下を試してください: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, ''));
/[^0-9]/g
に置き換え、btw はに置き換えることができるため/[^\d]/g
です。
このコードで上記のすべての組み合わせを試してみて、それを機能させました-その文字列で機能したのはそれだけでした->(12) 3456-7890
var str="(12) 3456-7890";
str.replace( /\D+/g, '');
結果: "1234567890"
Obs:そのような文字列はattrにはないことを知っていますが、より完全なため、ソリューションの方が優れています。
str.match(/\d+/g).map(Number)
配列を返すほうがいいと思います
あなたは素晴らしいparseIntメソッドを使うかもしれません
先頭の数字を数値に変換します
parseInt("-10px");
// will give you -10
などの文字列の場合#box2
、これは機能するはずです。
var thenum = thestring.replace(/^.*?(\d+).*/,'$1');
jsFiddle:
正規表現を使用できます。
var txt="some text 2";
var numb = txt.match(/\d/g);
alert (numb);
それは警告します2。
で正規表現、どのように例えば、文字列から数値を取得します:
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 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);
}
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の出力が必要なので、replaceを使用しました
$('#help_number').keyup(function(){
$(this).val($(this).val().match(/\d+/g).join("").replace(/(\d{3})\-?(\d{3})\-?(\d{4})/,'$1-$2-$3'))
});
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)/');