D3.js-배열 API

D3에는 모듈 모음이 포함되어 있습니다. 각 모듈을 독립적으로 사용하거나 모듈 모음을 함께 사용하여 작업을 수행 할 수 있습니다. 이 장에서는 Array API에 대해 자세히 설명합니다.

어레이 란?

배열에는 동일한 유형의 요소의 고정 크기 순차 컬렉션이 포함됩니다. 배열은 데이터 모음을 저장하는 데 사용되지만 배열을 동일한 유형의 변수 모음으로 생각하는 것이 더 유용합니다.

API 구성

아래 스크립트를 사용하여 API를 쉽게 구성 할 수 있습니다.

<script src = "https://d3js.org/d3-array.v1.min.js"></script>
<body>
   <script>
   </script>
</body>

배열 통계 API 메서드

다음은 가장 중요한 배열 통계 API 메소드 중 일부입니다.

  • d3.min(array)
  • d3.max(array)
  • d3.extent(array)
  • d3.sum(array)
  • d3.mean(array)
  • d3.quantile(array)
  • d3.variance(array)
  • d3.deviation(array)

각각에 대해 자세히 논의하겠습니다.

d3.min (배열)

자연 순서를 사용하여 주어진 배열의 최소값을 반환합니다.

Example − 다음 스크립트를 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.min(data));
</script>

Result − 위 스크립트는 콘솔의 배열 20에 최소값을 반환합니다.

d3.max (배열)

주어진 배열에서 최대 값을 반환합니다.

Example − 다음 스크립트를 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.max(data));
</script>

Result − 위 스크립트는 콘솔의 배열 (100)에서 최대 값을 반환합니다.

d3.extent (배열)

주어진 배열의 최소값과 최대 값을 반환합니다.

Example − 다음 스크립트를 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.extent(data));
</script>

Result − 위 스크립트는 익스텐트 값 [20,100]을 반환합니다.

d3.sum (배열)

주어진 숫자 배열의 합을 반환합니다. 배열이 비어 있으면 0을 반환합니다.

Example − 아래 사항을 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.sum(data));
</script>

Result − 위 스크립트는 합계 값이 300을 반환합니다.

d3.mean (배열)

주어진 숫자 배열의 평균을 반환합니다.

Example − 아래 사항을 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.mean(data));
</script>

Result − 위 스크립트는 평균값을 60으로 반환합니다. 마찬가지로 중앙값을 확인할 수 있습니다.

d3.quantile (배열)

주어진 정렬 된 숫자 배열의 p- 분위수를 반환합니다. 여기서 p는 [0, 1] 범위의 숫자입니다. 예를 들어, 중앙값은 p = 0.5, p = 0.25에서 1 사 분위, p = 0.75에서 3 사 분위를 사용하여 계산할 수 있습니다. 이 구현은 R-7 방법, 기본 R 프로그래밍 언어 및 Excel을 사용합니다.

Example − 다음 예를 고려하십시오.

var data = [20, 40, 60, 80, 100];
d3.quantile(data, 0); // output is 20
d3.quantile(data, 0.5); // output is 60
d3.quantile(data, 1); // output is 100

마찬가지로 다른 값을 확인할 수 있습니다.

d3.variance (배열)

주어진 숫자 배열의 분산을 반환합니다.

Example − 다음 스크립트를 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.variance(data));
</script>

Result − 위 스크립트는 분산 값을 1000으로 반환합니다.

d3.deviation (array)

주어진 배열의 표준 편차를 반환합니다. 배열에 두 개 미만의 값이 있으면 undefined로 반환됩니다.

Example − 아래 사항을 고려하십시오.

<script>
   var data = [20,40,60,80,100];
   console.log(d3.deviation(data));
</script>

Result − 위 스크립트는 편차 값을 31.622776601683793으로 반환합니다.

Example− 위에서 설명한 모든 Array API 메서드를 다음 스크립트를 사용하여 수행해 보겠습니다. 웹 페이지 "array.html"을 만들고 다음 변경 사항을 추가합니다.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         var data = [20,40,60,80,100];
         console.log(d3.min(data));  
         console.log(d3.max(data));
         console.log(d3.extent(data));
         console.log(d3.sum(data));
         console.log(d3.mean(data));
         console.log(d3.quantile(data,0.5));
         console.log(d3.variance(data));
         console.log(d3.deviation(data));
      </script>
   </body>
</html>

이제 브라우저를 요청하면 다음과 같은 응답이 표시됩니다.

배열 검색 API 메서드

다음은 몇 가지 중요한 배열 검색 API 메서드입니다.

  • d3.scan(array)
  • d3. 오름차순 (a, b)

이 두 가지를 자세히 이해합시다.

d3.scan (배열)

이 방법은 지정된 배열의 선형 스캔을 수행하는 데 사용됩니다. 최소 요소의 인덱스를 지정된 비교기로 반환합니다. 간단한 예가 아래에 정의되어 있습니다.

Example

var array = [{one: 1}, {one: 10}];
console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // output is 0
console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // output is 1

d3. 오름차순 (a, b)

이 방법은 비교기 기능을 수행하는 데 사용됩니다. 그것은 다음과 같이 구현 될 수 있습니다-

function ascending(a, b) {
   return a < b ? -1 : a > b ? 1 : a > =  b ? 0 : NaN;
}

내장 정렬 방법에 비교기 기능이 지정되지 않은 경우 기본 순서는 알파벳순입니다. 위의 함수는 a가 b보다 작 으면 -1을 반환하고 a가 b보다 크면 1을 반환하거나 0을 반환합니다.

마찬가지로 내림차순 (a, b) 메서드를 수행 할 수 있습니다. a가 b보다 크면 -1을, a가 b보다 작 으면 1을 반환하거나 0을 반환합니다.이 함수는 역방향 자연 순서를 수행합니다.

Example

웹 페이지 만들기 array_search.html 다음 변경 사항을 추가하십시오.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         var array = [{one: 1}, {one: 10}];
         console.log(d3.scan(array, function(a, b) { return a.one - b.one; })); // 0
         console.log(d3.scan(array, function(a, b) { return b.one - a.one; })); // 1
      </script>
   </body>
</html>

이제 브라우저를 요청하면 다음 결과가 표시됩니다.

배열 변환 API

다음은 가장 눈에 띄는 배열 변환 API 메서드 중 일부입니다.

  • d3.cross (a, b [, 감속기])
  • d3.merge(arrays)
  • d3.pairs (array [, reducer])
  • d3.permute (배열, 인덱스)
  • d3.zip(arrays)

이들 각각을 자세히 이해합시다.

d3.cross (a, b [, 감속기])

이 메서드는 주어진 두 배열 a와 b의 데카르트 곱을 반환하는 데 사용됩니다. 간단한 예가 아래에 정의되어 있습니다.

d3.cross([10, 20], ["a", "b"]); // output is [[10, "a"], [10, "b"], [20, "a"], [20, "b"]]

d3.merge (배열)

이 방법은 배열을 병합하는 데 사용되며 아래에 정의되어 있습니다.

d3.merge([[10], [20]]); // output is [10, 20]

d3.pairs (array [, reducer])

이 메서드는 배열 요소를 쌍으로 만드는 데 사용되며 아래에 정의되어 있습니다.

d3.pairs([10, 20, 30, 40]); // output is [[10, 20], [20, 30], [30, 40]]

d3.permute (배열, 인덱스)

이 메서드는 지정된 배열 및 인덱스에서 순열을 수행하는 데 사용됩니다. 객체의 값을 배열로 수행 할 수도 있습니다. 아래에 설명되어 있습니다.

var object = {fruit:"mango", color: "yellow"},
   fields = ["fruit", "color"];
d3.permute(object, fields); // output is "mango" "yellow"

d3.zip (배열)

이 메서드는 배열 배열을 반환하는 데 사용됩니다. 배열에 단일 배열 만 포함 된 경우 반환 된 배열에는 요소가 하나 인 배열이 포함됩니다. 인수를 지정하지 않으면 반환 된 배열이 비어 있습니다. 아래에 정의되어 있습니다.

d3.zip([10, 20], [30, 40]); // output is [[10, 30], [20, 40]]

Example − 웹 페이지 생성 array_transform 다음 변경 사항을 추가하십시오.

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <h3>D3 array API</h3>
      <script>
         console.log(d3.cross([10, 20], ["a", "b"]));
         console.log(d3.merge([[10], [30]]));
         console.log(d3.pairs([10, 20, 30, 40]));
         var object = {fruit:"mango", color: "yellow"},
         fields = ["fruit", "color"];
         console.log(d3.permute(object, fields)); 
         console.log(d3.zip([10, 20], [30, 40]));
      </script>
   </body>
</html>

이제 브라우저를 요청하면 다음과 같은 응답이 표시됩니다.