当前位置: 首页 > 知识库问答 >
问题:

计算csv中每列总和的列表

昌博易
2023-03-14

我试图计算每列CSV的总和。我能够读取csv在js使用readfile方法。我也能够循环使用它,并将数据解析成对象数组。现在我只是想出一种方法来把所有的列元素加起来,这就是我正在努力的地方。我的csv对象是对象格式的数组,看起来像这样。

[
  { item: '18', count: '180' },
  { item: '19', count: '163' },
  { item: '20', count: '175' },
  { item: '', count: undefined }
]

CSV输入如下所示:

item,count
18,180
19,163
20,175

我想补充18 19 20最终答案应该是这样的[57,518]。

到目前为止,我已经完成了这些工作,我只需要帮助来改进这一点,并在JS中按列添加逻辑,请提供帮助。

       const fs = require('fs')
        let result = []

        var dataArray = []
        fs.readFile(filename, 'utf8', function (err, data) {
            dataArray = data.split(/\r?\n/);
            // console.log("dataArray", dataArray)
            var headers = dataArray[0].split(",");


            for (var i = 1; i < dataArray.length; i++) {

                var obj = {};
                console.log("dataArray", dataArray)
                var currentline = dataArray[i].split(",");


                for (var j = 0; j < headers.length; j++) {
                    obj[headers[j]] = currentline[j];
                }

                result.push(obj);

            }

        })
 

共有1个答案

缪宪
2023-03-14

您可以使用array#reducearray#forEach对csv的每一行进行迭代,并对计数的值进行汇总。

const fs = require('fs').promises;

const fileName = 'data.csv'

const calculateSum = async () => {
    const data = await fs.readFile(fileName, 'utf-8');
    const dataArray = data.split(/\r?\n/);
    const header = dataArray[0].split(',')
    const result = dataArray.slice(1).reduce((sum, arr) => {
        arr.split(',').forEach((v, i) => {
            sum[i] = (sum[i] || 0) + Number(v.trim());
        })
        return sum;
    }, []);
    console.log(result);
}
 类似资料:
  • 本文向大家介绍F# 计算列表中数字的总和,包括了F# 计算列表中数字的总和的使用技巧和注意事项,需要的朋友参考一下 示例 通过递归 上面的例子表示:“看list,它是空返回0,否则它是一个非空列表所以它可能是?。 [1],[1; 2][1; 2; 3]等,如果list是[1]然后将其绑定变量head到1并tail以[]再执行head + sumTotal tail。 执行示例: 封装上述模式的更通

  • 问题内容: 最近在一次采访中我遇到了编程问题。 有2个链接列表。每个节点存储一个从1到9的值(指示数字的一个索引)。因此123将是链表1-> 2-> 3 任务是创建一个函数: 这将返回2个链表争论中的值之和。 如果数组a为:1-> 2-> 3-> 4 数组b为:5-> 6-> 7-> 8 答案应该是:6-> 9-> 1-> 2 这是我的算法: 遍历a和b中的每个节点,获取作为整数的值并将其相加。使

  • 我的教授让我编写一个程序来读取. csv文件(778行(包括头行),8列)。我需要:1.编写一个方法来接收文件的名称作为其参数,然后打印文件中的行数。 公共无效printNumberOfLinesInFile(字符串文件名) public void printNumberOfPrivateNonPrivateCollegesInFile(字符串文件名) public void printMostE

  • 问题内容: 我正在使用SQLite,并尝试返回该列中某一列的总数,同时返回所有数据。我不想/不需要对数据进行分组,因为我需要在每个返回的行中都包含数据。 当我包含类似内容时, 它仅返回一行。我需要所有返回的行以及所有条目的总数。 问题答案: 听起来这就是您要寻找的内容: 参见带有演示的SQL Fiddle

  • 问题内容: 我的表中的一列中包含大量BLOB数据。我正在编写一个实用程序以将数据转储到文件系统。但是在转储之前,我需要检查磁盘上是否有必要的空间来导出整个表中的所有Blob字段。 请提出一种有效的方法来获取表中所有Blob字段的大小。 问题答案: 您可以使用MySQL函数。有关更多详细信息,请参见此处。

  • 问题内容: 我有一个模特 我试图这样做来计算此查询集中的总和: 此查询有什么问题?还是有其他方法可以计算列总和? 我知道这可以通过在queryset上使用for循环来完成,但是我需要一个优雅的解决方案。 问题答案: 你可能正在寻找