如何从数组中分割和获取选择数据

时间:2016-01-29 04:23:20

标签: javascript jquery arrays

我在JavaScript中有这样的数组

var a = [1,2,3,4,5,"4","12","2",6,7,"4",3,"2"]; 

我的问题是

  1. 如何拆分要更改的数组,(逗号)为“;”

  2. 如何返回数组中的字符串数以及返回总值而不管变量类型。

  3. 如何返回平均值(无论变量类型如何)

5 个答案:

答案 0 :(得分:1)

回答问题1

1.将其转换为字符串

var x=a.toString();

2.执行全局替换

var y= x.replace(/,/g,";");

3.这会给你"1;2;3;4;5;4;12;2;6;7;4;3;2"

问题2 只需使用a.length方法。这将为您提供元素总数。我不确定String元素部分。

答案 1 :(得分:1)

更改数组分隔符:

a.join(';');

引用为here

数组中的字符串数:

var stringCount = 0;
for (var i = 0; i < a.length; i++){
  if (typeof a[i] === 'string'){
    stringCount++;
  }
}

alert("The number of strings is: " + stringCount);

在此测试:https://jsfiddle.net/6c42nugy/2/

数组中所有元素的数量:

var entireLength = a.length;

与整体相比的每种类型的百分比

var stringPerc = (stringCount)/(stringCount + entireLength)

var otherPerc = (entireLength - stringCount)/(stringCount + entireLength)

答案 2 :(得分:0)

使用a.join(';');将数组转换为以分号分隔的字符串。

要返回数组中的字符串数,只需遍历它并使用toString.call(),如下所示:

var total = 0;
for (var i = 0, n = a.length; i < n; i++) {
    if (toString.call(a[i]) === '[object String]') total++;
}

要简单地返回项目总数,您可以a.length

如果你想要总和所有元素中的总值,你可以这样做:

var total = 0;
for (var i = 0, n = a.length; i < n; i++) {
    total += parseInt(a[i]);
}

如果您想要平均值,只需使用上面的代码并执行total / a.length;

答案 3 :(得分:0)

这是我的版本:

var a = [1,2,3,4,5,"4","12","2",6,7,"4",3,"2"], sum = 0, strings = 0;

var joined = a.join(';');
console.log("Joined: " + joined);

for (var i = 0; i < a.length; i++) {
    sum += parseInt(a[i]);

    if (typeof a[i] === "string") {
        strings++;
    }
}

var avg = sum / a.length;

console.log('Sum: ' + sum);
console.log('Average: ' + avg);
console.log('Strings: ' + strings);

并链接到JSFiddle

答案 4 :(得分:0)

所有结果都在一个循环中。

0 ... n-4:数据
n-3:所有字符串的计数
n-2:总和
n-1:平均值

var data = [1, 2, 3, 4, 5, "4", "12", "2", 6, 7, "4", 3, "2"],
    result = data.concat(data.reduce(function (r, a, i) {
        typeof a === 'string' && r[0]++;
        r[1] += +a;
        r[2] = r[1] / i;
        return r;
    }, [0, 0, 0])).join(';');

document.write('<pre>' + JSON.stringify(result, 0, 4) + '</pre>');