Мені потрібно перевірити, чи justPrices[i].substr(commapos+2,1).
Рядок - це щось на кшталт: "blabla, 120"
У цьому випадку він перевірить, чи є "0" число. Як це можна зробити?
Мені потрібно перевірити, чи justPrices[i].substr(commapos+2,1).
Рядок - це щось на кшталт: "blabla, 120"
У цьому випадку він перевірить, чи є "0" число. Як це можна зробити?
Відповіді:
Ви можете скористатися операторами порівняння, щоб побачити, чи знаходиться він у діапазоні цифр:
var c = justPrices[i].substr(commapos+2,1);
if (c >= '0' && c <= '9') {
// it is a number
} else {
// it isn't
}
ви можете або скористатися parseIntі, ніж перевіритиisNaN
або якщо ви хочете працювати безпосередньо над рядком, ви можете скористатися таким чином:
function is_numeric(str){
return /^\d+$/.test(str);
}
function is_numeric_char(c) { return /\d/.test(c); }
is_numeric_char("foo1bar") == true). якщо ви хочете перевірити чисельний знак, /^\d$/.test(c)було б кращим рішенням. але все одно, це не було питання :)
EDIT: Оновлена відповідь Blender - це правильна відповідь, якщо ви просто перевіряєте один символ (а саме !isNaN(parseInt(c, 10))). Моя відповідь нижче - хороше рішення, якщо ви хочете перевірити цілі рядки.
Ось isNumericреалізація jQuery (у чистому JavaScript), яка працює проти повних рядків :
function isNumeric(s) {
return !isNaN(s - parseFloat(s));
}
У коментарі до цієї функції написано:
// parseFloat NaNs числові відкидні помилкові позитиви (null | true | false | "")
// ... але неправильно трактує рядки провідних чисел, зокрема шістнадцяткові літерали ("0x ...")
// віднімання примушує нескінченності до NaN
Я думаю, ми можемо вірити, що ці хлопці витратили на це досить багато часу!
Цікаво, чому ніхто не опублікував таке рішення, як:
var charCodeZero = "0".charCodeAt(0);
var charCodeNine = "9".charCodeAt(0);
function isDigitCode(n) {
return(n >= charCodeZero && n <= charCodeNine);
}
із викликом типу:
if (isDigitCode(justPrices[i].charCodeAt(commapos+2))) {
... // digit
} else {
... // not a digit
}
Ви можете скористатися цим:
function isDigit(n) {
return Boolean([true, true, true, true, true, true, true, true, true, true][n]);
}
Тут я порівняв його з прийнятим методом: http://jsperf.com/isdigittest/5 . Я мало чекав, тому був дуже здивований, коли дізнався, що прийнятий метод набагато повільніше.
Цікавим є те, що, хоча прийнятий метод - це швидше правильне введення даних (наприклад, "5") і повільніше для неправильного (наприклад, "a"), мій метод є прямо протилежним (швидкий для неправильного і повільніше для правильного).
Але в гіршому випадку мій метод у 2 рази швидший, ніж прийняте рішення для правильного введення і в 5 разів швидше для неправильного введення.
!!([!0, !0, !0, !0, !0, !0, !0, !0, !0, !0][n]);Він має великий потенціал WTF і працює досить добре (не вдається 007).
"length"(та інші атрибути, знайдені на масивах) - це цифри: P
Я думаю, що дуже цікаво придумати шляхи вирішення цього питання. Нижче наведено деякі.
(Усі функції, наведені нижче, припускають, що аргумент - це один символ. Змініть, щоб n[0]його застосувати)
function isCharDigit(n){
return !!n.trim() && n > -1;
}
function isCharDigit(n){
return !!n.trim() && n*0==0;
}
function isCharDigit(n){
return !!n.trim() && !!Number(n+.1); // "+.1' to make it work with "." and "0" Chars
}
var isCharDigit = (function(){
var a = [1,1,1,1,1,1,1,1,1,1];
return function(n){
return !!a[n] // check if `a` Array has anything in index 'n'. Cast result to boolean
}
})();
function isCharDigit(n){
return !!n.trim() && !isNaN(+n);
}
var str = ' 90ABcd#?:.+', char;
for( char of str )
console.log( char, isCharDigit(char) );
trueдля " ".
charCodeAt()порівняння - що було майже в 4 рази швидше - jsperf.com/isdigit3
Проста функція
function isCharNumber(c){
return c >= '0' && c <= '9';
}
Пропоную простий регекс.
Якщо ви шукаєте лише останнього символу в рядку:
/^.*?[0-9]$/.test("blabla,120"); // true
/^.*?[0-9]$/.test("blabla,120a"); // false
/^.*?[0-9]$/.test("120"); // true
/^.*?[0-9]$/.test(120); // true
/^.*?[0-9]$/.test(undefined); // false
/^.*?[0-9]$/.test(-1); // true
/^.*?[0-9]$/.test("-1"); // true
/^.*?[0-9]$/.test(false); // false
/^.*?[0-9]$/.test(true); // false
І регулярне вираження ще простіше, якщо ви просто перевіряєте одну таблицю як вхід:
var char = "0";
/^[0-9]$/.test(char); // true
Найкоротшим рішенням є:
const isCharDigit = n => n < 10;
Ви також можете застосувати їх:
const isCharDigit = n => Boolean(++n);
const isCharDigit = n => '/' < n && n < ':';
const isCharDigit = n => !!++n;
якщо ви хочете перевірити більше 1 символу, ви можете використовувати наступні варіанти
Регулярне вираження:
const isDigit = n => /\d+/.test(n);
Порівняння:
const isDigit = n => +n == n;
Перевірте, чи це не NaN
const isDigit = n => !isNaN(n);
isNumber = function(obj, strict) {
var strict = strict === true ? true : false;
if (strict) {
return !isNaN(obj) && obj instanceof Number ? true : false;
} else {
return !isNaN(obj - parseFloat(obj));
}
}
вихід без суворого режиму:
var num = 14;
var textnum = '14';
var text = 'yo';
var nan = NaN;
isNumber(num);
isNumber(textnum);
isNumber(text);
isNumber(nan);
true
true
false
false
вихід із суворим режимом:
var num = 14;
var textnum = '14';
var text = 'yo';
var nan = NaN;
isNumber(num, true);
isNumber(textnum, true);
isNumber(text, true);
isNumber(nan);
true
false
false
false
Це, здається, працює:
Статичне зв'язування:
String.isNumeric = function (value) {
return !isNaN(String(value) * 1);
};
Зв'язування прототипу:
String.prototype.isNumeric = function () {
return !isNaN(this.valueOf() * 1);
};
Він перевірить окремі символи, а також цілі рядки, щоб побачити, чи є вони числовими.
function is_numeric(mixed_var) {
return (typeof(mixed_var) === 'number' || typeof(mixed_var) === 'string') &&
mixed_var !== '' && !isNaN(mixed_var);
}
Ви можете спробувати це (працював у моєму випадку)
Якщо ви хочете перевірити, чи є перший символ рядка int:
if (parseInt(YOUR_STRING.slice(0, 1))) {
alert("first char is int")
} else {
alert("first char is not int")
}
Якщо ви хочете перевірити, чи знак є цілим:
if (parseInt(YOUR_CHAR)) {
alert("first char is int")
} else {
alert("first char is not int")
}
Ця функція працює для всіх тестових випадків, які я міг знайти. Це також швидше, ніж:
function isNumeric (n) {
if (!isNaN(parseFloat(n)) && isFinite(n) && !hasLeading0s(n)) {
return true;
}
var _n = +n;
return _n === Infinity || _n === -Infinity;
}
var isIntegerTest = /^\d+$/;
var isDigitArray = [!0, !0, !0, !0, !0, !0, !0, !0, !0, !0];
function hasLeading0s(s) {
return !(typeof s !== 'string' ||
s.length < 2 ||
s[0] !== '0' ||
!isDigitArray[s[1]] ||
isIntegerTest.test(s));
}
var isWhiteSpaceTest = /\s/;
function fIsNaN(n) {
return !(n <= 0) && !(n > 0);
}
function isNumber(s) {
var t = typeof s;
if (t === 'number') {
return (s <= 0) || (s > 0);
} else if (t === 'string') {
var n = +s;
return !(fIsNaN(n) || hasLeading0s(s) || !(n !== 0 || !(s === '' || isWhiteSpaceTest.test(s))));
} else if (t === 'object') {
return !(!(s instanceof Number) || fIsNaN(+s));
}
return false;
}
function testRunner(IsNumeric) {
var total = 0;
var passed = 0;
var failedTests = [];
function test(value, result) {
total++;
if (IsNumeric(value) === result) {
passed++;
} else {
failedTests.push({
value: value,
expected: result
});
}
}
// true
test(0, true);
test(1, true);
test(-1, true);
test(Infinity, true);
test('Infinity', true);
test(-Infinity, true);
test('-Infinity', true);
test(1.1, true);
test(-0.12e-34, true);
test(8e5, true);
test('1', true);
test('0', true);
test('-1', true);
test('1.1', true);
test('11.112', true);
test('.1', true);
test('.12e34', true);
test('-.12e34', true);
test('.12e-34', true);
test('-.12e-34', true);
test('8e5', true);
test('0x89f', true);
test('00', true);
test('01', true);
test('10', true);
test('0e1', true);
test('0e01', true);
test('.0', true);
test('0.', true);
test('.0e1', true);
test('0.e1', true);
test('0.e00', true);
test('0xf', true);
test('0Xf', true);
test(Date.now(), true);
test(new Number(0), true);
test(new Number(1e3), true);
test(new Number(0.1234), true);
test(new Number(Infinity), true);
test(new Number(-Infinity), true);
// false
test('', false);
test(' ', false);
test(false, false);
test('false', false);
test(true, false);
test('true', false);
test('99,999', false);
test('#abcdef', false);
test('1.2.3', false);
test('blah', false);
test('\t\t', false);
test('\n\r', false);
test('\r', false);
test(NaN, false);
test('NaN', false);
test(null, false);
test('null', false);
test(new Date(), false);
test({}, false);
test([], false);
test(new Int8Array(), false);
test(new Uint8Array(), false);
test(new Uint8ClampedArray(), false);
test(new Int16Array(), false);
test(new Uint16Array(), false);
test(new Int32Array(), false);
test(new Uint32Array(), false);
test(new BigInt64Array(), false);
test(new BigUint64Array(), false);
test(new Float32Array(), false);
test(new Float64Array(), false);
test('.e0', false);
test('.', false);
test('00e1', false);
test('01e1', false);
test('00.0', false);
test('01.05', false);
test('00x0', false);
test(new Number(NaN), false);
test(new Number('abc'), false);
console.log('Passed ' + passed + ' of ' + total + ' tests.');
if (failedTests.length > 0) console.log({
failedTests: failedTests
});
}
testRunner(isNumber)
Наскільки я знаю, найпростіший спосіб - просто помножити на 1:
var character = ... ; // your character
var isDigit = ! isNaN(character * 1);
Множення на одне робить число з будь-якого числового рядка (оскільки у вас є лише один символ, воно завжди буде цілим числом від 0 до 9) і а NaNдля будь-якого іншого рядка.
Подібно до однієї з відповідей вище, я використав
var sum = 0; //some value
let num = parseInt(val); //or just Number.parseInt
if(!isNaN(num)) {
sum += num;
}
Цей поштовий блог проливає ще трохи світла на цю перевірку, чи є рядок цифровим у Javascript | Typescript & ES6
Просте рішення за допомогою використання динамічної перевірки типу мови:
function isNumber (string) {
//it has whitespace
if(string === ' '.repeat(string.length)){
return false
}
return string - 0 === string * 1
}
див. тестові приклади нижче
Просто використовуйте isFinite
const number = "1";
if (isFinite(number)) {
// do something
}