繁体   English   中英

TypeError: parse is not a function on csv-parse

[英]TypeError: parse is not a function on csv-parse

在使用以下方法设置一个简单的应用程序后,我遇到了这个问题:

  • 节点 v16.13.2
  • npm v8.1.2
  • csv 解析 v5.0.4
  • VSCode v1.63.2

代码是:

const parse = require('csv-parse');
const fs = require('fs');

const results = [];

fs.createReadStream('kepler_data.csv')
    .pipe(parse({
        comment: "#",
        columns: true,
    }))
    .on('data', (data) => {
        results.push(data);
    })
    .on('error', (err) => {
        console.log(err);
    })
    .on('end', () => {
        console.log(results);
        console.log('Done!');
    });

运行它导致:

index.js:7
    .pipe(parse({
          ^

TypeError: parse is not a function
    at Object.<anonymous> (/home/jadeye/node.js_workspace/PLANETS-PROJECT/index.js:7:11)
    at Module._compile (node:internal/modules/cjs/loader:1101:14)
    at Object.Module._extensions..js (node:internal/modules/cjs/loader:1153:10)
    at Module.load (node:internal/modules/cjs/loader:981:32)
    at Function.Module._load (node:internal/modules/cjs/loader:822:12)
    at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:81:12)

搜索SO给出了类似的结果,但没有实际的解决方案。

解决方案很简单。 如果parse或任何其他 function 无法被node require识别,请尝试将 function 本身获取为:

const { parse } = require('csv-parse');

值得注意的是,强调const parse color = whitepipe = green中的 function parse之间的区别的配色方案。

错误的调用

并且 colors 没有错误,其中const { parse }green ,匹配const调用。

在此处输入图像描述

谢谢你救了我的一天。 一件事我只想知道您使用的是哪种颜色主题,以便我可以知道您在此问题中发现的相同差异。

而不是使用

常量 { 解析 } = 要求('csv-parse');

尝试关注

常量 { 解析 } = 要求(“csv 解析”);

通过执行 const {parse} = require("csv-parse"); 在 csv-parse 模块中获取解析 function

和 call.pipe(parse())

对我有用的是从“csv-parse”更改为“csv-parser”

在 package.json 中使用它

"csv-parser": "^3.0.0"

代替:

"csv-parse": "v5.0.4"
  1. 尝试const {parse} = require('parse')而不是const parse = require('parse')
  2. 尝试使用 csv-parse版本,而不是"csv-parse": "^3.0.0" of "csv-parse": "^5.3.0"

csv解析

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM