your programing

JavaScript에서 배열의 모든 요소를 ​​정수로 변환하는 방법은 무엇입니까?

lovepro 2020. 12. 27. 20:26
반응형

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대신 사용하세요.


원인:

  1. 작동 중입니다.

    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
    
  2. 더 짧습니다.

  3. 그것은 조금 더 빠르며-접근-하지 않을 때 캐시를 활용합니다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

반응형