JavaScript에서 배열의 모든 요소를 정수로 변환하는 방법은 무엇입니까?
약간의 조작 후 배열을 얻고 있습니다. 모든 배열 값을 정수로 변환해야합니다.
내 샘플 코드
var result_string = 'a,b,c,d|1,2,3,4';
result = result_string.split("|");
alpha = result[0];
count = result[1];
// console.log(alpha);
// console.log(count);
count_array = count.split(",");
count_array
이제 포함 1,2,3,4
하지만이 값이 정수 여야합니다.
을 사용 parseInt(count_array);
했지만 실패합니다. JS는이 배열의 각 값을 문자열로 간주합니다.
다음과 같이 배열의 요소를 반복하고 구문 분석 / 변환해야합니다.
var result_string = 'a,b,c,d|1,2,3,4',
result = result_string.split("|"),
alpha = result[0],
count = result[1],
count_array = count.split(",");
for(var i=0; i<count_array.length;i++) count_array[i] = +count_array[i];
//now count_array contains numbers
여기에서 테스트 할 수 있습니다 . +
, 던지는 경우 다음 과 같이 생각하십시오.
for(var i=0; i<count_array.length;i++) count_array[i] = parseInt(count_array[i], 10);
ECMAScript5는 배열의 모든 요소에 함수를 적용하는 s map
메서드를 제공합니다 Array
. 다음은 그 예입니다.
var a = ['1','2','3']
var result = a.map(function (x) {
return parseInt(x, 10);
});
console.log(result);
자세한 내용은 https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/map을 확인 하십시오.
넌 할 수있어
var arrayOfNumbers = arrayOfStrings.map(Number);
Array.map을 지원하지 않는 이전 브라우저의 경우 Underscore 를 사용할 수 있습니다.
var arrayOfNumbers = _.map(arrayOfStrings, Number);
var arr = ["1", "2", "3"];
arr = arr.map(Number);
console.log(arr); // [1, 2, 3]
배열을 반복하고 항목을 변환하십시오.
for(var i=0, len=count_array.length; i<len; i++){
count_array[i] = parseInt(count_array[i], 10);
}
parseInt에 대한 두 번째 인수를 잊지 마십시오.
접근에 대한 요점 parseInt
:
람다를 사용하거나 radix
매개 변수를 parseInt
에 지정할 필요가 없습니다 . parseFloat
또는 Number
대신 사용하세요.
원인:
작동 중입니다.
var src = "1,2,5,4,3"; var ids = src.split(',').map(parseFloat); // [1, 2, 5, 4, 3] var obj = {1: ..., 3: ..., 4: ..., 7: ...}; var keys= Object.keys(obj); // ["1", "3", "4", "7"] var ids = keys.map(parseFloat); // [1, 3, 4, 7] var arr = ["1", 5, "7", 11]; var ints= arr.map(parseFloat); // [1, 5, 7, 11] ints[1] === "5" // false ints[1] === 5 // true ints[2] === "7" // false ints[2] === 7 // true
더 짧습니다.
그것은 조금 더 빠르며-접근-하지 않을 때 캐시를 활용합니다
parseInt
.// execution time measure function // keep it simple, yeah? > var f = (function (arr, c, n, m) { var i,t,m,s=n(); for(i=0;i++<c;)t=arr.map(m); return n()-s }).bind(null, "2,4,6,8,0,9,7,5,3,1".split(','), 1000000, Date.now); > f(Number) // first launch, just warming-up cache > 3971 // nice =) > f(Number) > 3964 // still the same > f(function(e){return+e}) > 5132 // yup, just little bit slower > f(function(e){return+e}) > 5112 // second run... and ok. > f(parseFloat) > 3727 // little bit quicker than .map(Number) > f(parseFloat) > 3737 // all ok > f(function(e){return parseInt(e,10)}) > 21852 // awww, how adorable... > f(function(e){return parseInt(e)}) > 22928 // maybe, without '10'?.. nope. > f(function(e){return parseInt(e)}) > 22769 // second run... and nothing changes. > f(Number) > 3873 // and again > f(parseFloat) > 3583 // and again > f(function(e){return+e}) > 4967 // and again > f(function(e){return parseInt(e,10)}) > 21649 // dammit 'parseInt'! >_<
알림 : Firefox에서는 parseInt
약 4 배 더 빠르게 작동하지만 다른 것보다 느립니다. 총 : +e
< Number
< parseFloat
<parseInt
var inp=readLine();//reading the input as one line string var nums=inp.split(" ").map(Number);//making an array of numbers console.log(nums);
입력 : 19 0 65 5 7 출력 : [1, 9, 0, 65, 5, 7]
.map (Number)를 사용하지 않으면 어떻게 될까요?
암호 var inp=readLine();//reading the input as one line string var nums=inp.split(" ");//making an array of strings console.log(nums);
input : 1 9 0 65 5 7 output:[ '1', '9', '0', '65', '5', '7']
const arrString = ["1","2","3","4","5"];
const arrInteger = arrString.map(x => Number.parseInt(x, 10));
Above one should be simple enough,
One tricky part is when you try to use point free function for map as below
const arrString = ["1","2","3","4","5"];
const arrInteger = arrString.map(Number.parseInt);
In this case, result will be [1, NaN, NaN, NaN, NaN]
since function argument signature for map
and parseInt
differs
map expects -
(value, index, array)
where as parseInt expects -(value, radix)
Using jQuery, you can like the map()
method like so;
$.map(arr, function(val,i) {
return parseInt(val);
});
If you want to convert an Array of digits to a single number just use:
Number(arrayOfDigits.join(''));
Example
const arrayOfDigits = [1,2,3,4,5];
const singleNumber = Number(arrayOfDigits.join(''));
console.log(singleNumber); //12345
How about this:
let x = [1,2,3,4,5]
let num = +x.join("")
ReferenceURL : https://stackoverflow.com/questions/4437916/how-to-convert-all-elements-in-an-array-to-integer-in-javascript
'programing' 카테고리의 다른 글
MySQL : 조건이 충족되는 경우에만 필드 업데이트 (0) | 2020.12.27 |
---|---|
ADB 드라이버 및 Windows 8.1 (0) | 2020.12.27 |
ListActivity에 대한 AbsListView.obtainView의 ListView에서 충돌이 발생합니다. (0) | 2020.12.26 |
정수가 PHP에서 숫자 범위 내에 있는지 확인하는 방법은 무엇입니까? (0) | 2020.12.26 |
하단 내비게이션 바 아이콘 상단에 배지 표시 (0) | 2020.12.26 |