如何从nodejs的csv文件中按列读取数据?

时间:2019-01-06 20:46:28

标签: javascript node.js csv fs

我使用了“ fast-csv”模块来解析csv文件以进行其他操作,但这会按行返回数据。我想阅读csv文件的前2列。有人可以帮忙吗?

1 个答案:

答案 0 :(得分:1)

我看到两个选择。

一种方法是在fast-csv中指定所需的标头,并丢弃其余标头。这种方法将返回一个可能满足您需求的对象,或者您之后可以将其转换为数组。

const csv = require('fast-csv')

const CSV_STRING = 'a,b,c\n' +
                     'a1,b1,c1\n' +
                     'a2,b2,c2\n'

let filtered = []
csv
  .fromString(CSV_STRING, { headers: ['column_1', 'column_2'], renameHeaders: true, discardUnmappedColumns: true }) // I give arbitrary names to the first two columns - use whatever make sense
  // .fromString(CSV_STRING, { headers: ['column_1', undefined, 'column_3'], discardUnmappedColumns: true }) // I could use undefined if I wanted to say skip column 2 and just want 1 and 3
  .on('data', function (data) {
    // console.log([data.column_1, data.column_2])
    filtered.push([data.column_1, data.column_2]) // or you can push to an array
  })
  .on('end', function () {
    console.log('done')
    console.log(filtered)
  })

另一种方法是返回数组(默认)并使用transform方法过滤所需的内容

const csv = require('fast-csv')

const CSV_STRING = 'a,b,c\n' +
                     'a1,b1,c1\n' +
                     'a2,b2,c2\n'

csv
  .fromString(CSV_STRING)
  .transform(function (data) {
    return [data[0], data[1]]
  })
  .on('data', function (data) {
    console.log(data)
  })
  .on('end', function () {
    console.log('done')
  })