ネストされた配列の最大値を見つけたいのですが、次のようになります。
a = [[1,2],[20,3]]
d3.max(d3.max(a)) // 20
しかし、私の配列には、破棄したいテキストフィールドが含まれています。
a = [["yz",1,2],["xy",20,3]]
d3.max(a) // 20
ネストされた配列の最大値を見つけたいのですが、次のようになります。
a = [[1,2],[20,3]]
d3.max(d3.max(a)) // 20
しかし、私の配列には、破棄したいテキストフィールドが含まれています。
a = [["yz",1,2],["xy",20,3]]
d3.max(a) // 20
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);
});
これを使って:
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を参照してください。
配列をフラット化して、各メンバーに関数を適用できます
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));
テストする列が正確にわかった場合は、次を使用できます。
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;
}
これは残酷なハックですが、のソースコードを見ると、最初の要素をコピーして最初の要素を破棄するが、に置き換えるようにd3.max
定義するのが最善の策かもしれません。そのリンクのコードはここから抜粋されています。私は通常のd3.jsユーザーではありませんが、ライブラリについて私が知っていることから、ライブ更新に正しく応答できるように、バージョンにこの関数のようなケースがあることを確認する必要があります。d3.max1
i=-1
i=0
f.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))
。
d3.array
d3.merge
配列の配列を平坦化するものを提供します。
アクセサとしてのd3.max
javascriptと組み合わせ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>