32

ネストされた配列の最大値を見つけたいのですが、次のようになります。

a = [[1,2],[20,3]]
d3.max(d3.max(a)) // 20

しかし、私の配列には、破棄したいテキストフィールドが含まれています。

a = [["yz",1,2],["xy",20,3]]
d3.max(a) // 20
4

6 に答える 6

77

arrays = [[1, 2], [20, 3]]数値のネストされた配列( )がある場合は、d3.maxをネストします。

var max = d3.max(arrays, function(array) {
  return d3.max(array);
});

または同等に、array.mapを使用します。

var max = d3.max(arrays.map(function(array) {
  return d3.max(array);
}));

文字列値を無視する場合は、array.filterを使用して文字列を無視できます。

var max = d3.max(arrays, function(array) {
  return d3.max(array.filter(function(value) {
    return typeof value === "number";
  }));
});

または、文字列が常に最初の位置にあることがわかっている場合は、少し効率的なarray.sliceを使用できます。

var max = d3.max(arrays, function(array) {
  return d3.max(array.slice(1));
});

NaNさらに別のオプションは、数値ではない値を返すアクセサ関数を使用することです。これにより、d3.maxはこれらの値を無視します。便利なことに、JavaScriptの組み込みNumber関数はまさにこれを行うので、次のように言うことができます。

var max = d3.max(arrays, function(array) {
  return d3.max(array, Number);
});
于 2012-05-12T20:15:26.657 に答える
5

これを使って:

function arrmax(arrs) {
    var toplevel = [];

    var f = function(v) {
        return !isNaN(v);
    };

    for (var i = 0, l = arrs.length; i<l; i++) {
        toplevel.push(Math.max.apply(window, arrs[i].filter(f)));
    }
    return Math.max.apply(window, toplevel);
}

以上:

function arrmax(arrs) {
    if (!arrs || !arrs.length) return undefined;
    var max = Math.max.apply(window, arrs[0]), m,
        f = function(v){ return !isNaN(v); };
    for (var i = 1, l = arrs.length; i<l; i++) {
        if ((m = Math.max.apply(window, arrs[i].filter(f)))>max) max=m;
    }
    return max;
}

Array.filterメソッドの詳細については、MDNを参照してください。

于 2012-05-12T14:25:10.057 に答える
3

配列をフラット化して、各メンバーに関数を適用できます

Array.prototype.flatten= function(fun){
    if(typeof fun!= 'function') fun= '';
    var A= [], L= this.length, itm;
    for(var i= 0; i<L; i++){
        itm= this[i];
        if(itm!= undefined){
            if(!itm.flatten){
                if(fun) itm= fun(itm);
                if(itm) A.push(itm);
            }
            else A= A.concat(itm.flatten(fun));
        }
    }
    return A;
}

var a= [["yz", 1, 2], ["xy", 20, 3]], max=-Infinity;

var max=Math.max.apply(a, a.flatten(Number));
于 2012-05-12T15:19:20.593 に答える
3

テストする列が正確にわかった場合は、次を使用できます。

var columns = ["ColumnA", "ColumnB", "ColumnC"];

var max = selectedMax(columns,dataset);
var min = selectedMin(columns,dataset)

function selectedMax(columns, dataset) {
    var max;
    columns.forEach(function(element, index, array) {
        var tmpmax = d3.max(dataset, function(d) {
            return +d[element];
        });       
        max = (tmpmax > max || max === undefined) ? tmpmax : max;
    });
    return max;
}

function selectedMin(columns, dataset) {
    var min;
    columns.forEach(function(element, index, array) {
        var tmpmin = d3.min(dataset, function(d) {
            return +d[element];
        });
        min = (tmpmin < min || min === undefined) ? tmpmin : min;
    });  
return min;
}
于 2013-05-08T12:00:20.777 に答える
0

これは残酷なハックですが、のソースコードを見ると、最初の要素をコピーして最初の要素を破棄するが、に置き換えるようにd3.max定義するのが最善の策かもしれません。そのリンクのコードはここから抜粋されています。私は通常のd3.jsユーザーではありませんが、ライブラリについて私が知っていることから、ライブ更新に正しく応答できるように、バージョンにこの関数のようなケースがあることを確認する必要があります。d3.max1i=-1i=0f.call

d3.max = function(array, f) {
  var i = -1,
      n = array.length,
      a,
      b;
  if (arguments.length === 1) {
    while (++i < n && ((a = array[i]) == null || a != a)) a = undefined;
    while (++i < n) if ((b = array[i]) != null && b > a) a = b;
  } else {
    while (++i < n && ((a = f.call(array, array[i], i)) == null || a != a)) a = undefined;
    while (++i < n) if ((b = f.call(array, array[i], i)) != null && b > a) a = b;
  }
  return a;
};

それならそれはただですd3.max(d3.max1(a))

于 2012-05-12T14:19:26.660 に答える
0

d3.arrayd3.merge配列の配列を平坦化するものを提供します。

アクセサとしてのd3.maxjavascriptと組み合わせNumberて:

var max = d3.max(d3.merge(arrays), Number);

例えば:

var input = [["yz", 1, 2], ["xy", 20, 3]];

var max = d3.max(d3.merge(input), Number);

console.log(max);
<script src="https://d3js.org/d3-array.v2.min.js"></script>

于 2019-06-16T15:35:19.193 に答える