这是我的数据集:
dfg= [[{"key":"Product_Description","value":"$49.95 Plan"},{"key":">20MB/30","value":44555},{"key":">200MB/30","value":36599},{"key":">2048MB/30","value":16173},{"key":">5120MB/30","value":6380},{"key":">10240MB/30","value":2178}],[{"key":"Product_Description","value":"$39.95 Plan"},{"key":">20MB/30","value":54832},{"key":">200MB/30","value":42988},{"key":">2048MB/30","value":14826},{"key":">5120MB/30","value":4742},{"key":">10240MB/30","value":1567}]]
我想通过此函数传递它,以便将上面的值更改为“Product Description”总值的百分比
//funtion to format data for percent values
function format_data_to_percent(d){
var data = d
data.map(function(a){
var sum = a.slice(1).map(function(a){ return a.value; }).reduce(function(a,b){return a*1+b*1},0);
//console.log("sum",sum);
a.slice(1).filter(function(a){
//console.log(a)
a.value=a.value/sum
//console.log(a)
});
return a;
})
//START TEST
// create a test case for it // make this better
vals=data_p[0].slice(1).map(function(a){ return a.value; })
//["11", "33", "10", "55", "10"]
sum = data_p[0].slice(1).map(function(a){ return a.value; }).reduce(function(a, b){return a*1+b*1},0);
//119
vals2=vals.map(function(a){ return a/sum})
//[0.09243697478991597, 0.2773109243697479, 0.08403361344537816, 0.46218487394957986, 0.08403361344537816]
console.log("test1--> ",data[0][1].value == vals2[0])
console.log("test2--> ",data[0][2].value == vals2[1])
console.log("test3--> ",data[0][3].value == vals2[2])
console.log("test4--> ",data[0][4].value == vals2[3])
console.log("test5--> ",data[0][5].value == vals2[4])
//END TEST
return data
}
dfg2=format_data_to_percent(dfg) //format my dataset
这就是我得到的我想要的
[[{"key":"Product_Description","value":"$49.95 Plan"},{"key":">20MB/30","value":0.42078670255465833},{"key":">200MB/30","value":0.345648581007697},{"key":">2048MB/30","value":0.15274118147046323},{"key":">5120MB/30","value":0.06025404920432545},{"key":">10240MB/30","value":0.02056948576285593}],[{"key":"Product_Description","value":"$39.95 Plan"},{"key":">20MB/30","value":0.4609474170904964},{"key":">200MB/30","value":0.3613803539153461},{"key":">2048MB/30","value":0.12463536631499307},{"key":">5120MB/30","value":0.03986381404732882},{"key":">10240MB/30","value":0.013173048631835568}]]
但是dfg也等于df2,我希望dfg保持和数字一样,dfg2有百分比。
我正在做的不是最佳实践。我理解,虽然不像我希望的那样完整,但数组中的对象都是相同的引用。但有并没有一种方法可以用数值实现dfg,用百分比值实现dfg2?
我是通过这个来的,这个通过切片原始阵列来复制阵列。我已经试过了,但在我的例子中不起作用,可能在那个例子中并没有对象,而我的数组中有对象。
edit1可能重复这里,但这是更多的java。这也许就是我想要的
直接分配数组时,它是javascript中的引用分配。这意味着任何变化都将反映在这两个方面。要复制数组,需要调用数组。切片()。
注意:这仍然是一个多维数组的赋值,所以你需要写一些递归的东西来复制一个有多个维度的数组(在任何元素,例如[1,2,['一些','内部','数组'],3])
tks to anser如下:仅供参考,这里是我的浏览器的完整日志
dfg
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
var arr2 = []
undefined
arr2.push(JSON.parse(JSON.stringify(dfg[0])))
1
arr2.push(JSON.parse(JSON.stringify(dfg[1])))
2
arr2
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
//funtion to format data for percent values func...alue == vals2[4]) //END TEST return data }
undefined
var arr3 = format_data_to_percent(arr2)
test1--> true
test2--> true
test3--> true
test4--> true
test5--> true
undefined
arr3
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=0.37336024217961655}, Object { key=">200MB/30", value=0.3113017154389506}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=0.3815028901734104}, Object { key=">200MB/30", value=0.32947976878612717}, 3 more...]]
dfg
[[Object { key="Product_Description", value="$100.83 Business Select Plan excl GST"}, Object { key=">20MB/30", value=1480}, Object { key=">200MB/30", value=1234}, 3 more...], [Object { key="Product_Description", value="$119.95 Business Share Everything Plan"}, Object { key=">20MB/30", value=66}, Object { key=">200MB/30", value=57}, 3 more...]]
可以克隆阵列的对象。
例如:
var arr = [{'one': 1}, {'two': 2}];
var arr2 = [];
arr2.push(JSON.parse(JSON.stringify(arr[0])));
arr2现在将使用JSON拥有arr[0]的独立副本。解析w/JSON。严格化。可以使用for循环、for each或map复制原始数组中的所有对象。
克隆阵列?这样,您将获得原始数组的副本,而不是原始数组的引用数组。
如果您使用的是jquery,那么就可以使用。延伸
var array_1 = [{},{},{}];
var array_2 = $.extend({}, true, array_1); // deep clone
或者你可以使用一些新的JavaScript。虽然这只执行浅拷贝,因此可能不适合您的用例,但我使用的是移动应用程序,因此无法使用您的代码。。
var array_2 = Object.assign({}, array_1);
问题内容: 我想创建一个1D NumPy数组,该数组由另一个1D数组的1000个背对背重复组成,而无需将数据复制1000次。 可能吗? 如果有帮助,我打算将两个数组都视为不可变的。 问题答案: 你做不到 NumPy数组在每个维度上必须具有一致的步幅,而您的步幅在大多数情况下需要采用一种方式,但有时会向后跳。 您可以获得的最接近的结果是一个1000行的2D数组,其中的每一行都是您第一个数组的视图,或
问题内容: 我有一些类库,正在处理我的数据,这些数据正在读入缓冲区。是否有可能以某种方式避免一次又一次地复制数组,从而将越来越多的数据部分传递给处理方法?好吧,这听起来很奇怪,但是在我的特殊情况下,有一个特殊的writer,它将数据分成多个块并将它们分别写入不同的位置,因此它只执行System.arraycopy,获取所需内容并使用该新名称调用底层writer。子数组。这会发生很多次。重构此类代码
我想从平面数组构建一个树形数组: 下面是平面数组: NB:id=节点id;pid=父节点id。 我想将其转换为这个数组: 我试图使用递归函数来实现预期的结果,但我正在寻找更好的方法。谢谢你的回复。
问题内容: 我有一个a不断更新的数组。比方说。我需要制作一个完全相同的副本a并称之为b。如果a要改成,b应该还是。做这个的最好方式是什么?我尝试了像这样的循环: 但这似乎无法正常工作。请不要使用深层复制等高级术语,因为我不知道这意味着什么。 问题答案: 你可以尝试使用System.arraycopy()
主要内容:使用 copyOf() 方法和 copyOfRange() 方法,使用 arraycopy() 方法,使用 clone() 方法所谓复制数组,是指将一个数组中的元素在另一个数组中进行复制。本文主要介绍关于 Java 里面的数组复制(拷贝)的几种方式和用法。 在 Java 中实现数组复制分别有以下 4 种方法: Arrays 类的 copyOf() 方法 Arrays 类的 copyOfRange() 方法 System 类的 arraycopy() 方法 Object 类的 clone
我正在尝试将来自我的数据库的对象的平面数组转换为需要嵌套结构才能管理可扩展子行的react-table。 我已经制作了一个代码沙盒,它非常简单: https://codesandbox.io/s/tender-chatterjee-kdssi?file=/src/App.js 基本上,我的原始数据结构如下: 我想把它转换成这个结构: 我已经尝试了一些递归的方法,但是他们留下了一些选择,所以我很乐意
我知道要在数组中查找值是否存在,我可以使用indexOf,但如何使用对象数组呢?