dsv2json 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637
  1. #!/usr/bin/env node
  2. var os = require("os"),
  3. rw = require("rw").dash,
  4. path = require("path"),
  5. iconv = require("iconv-lite"),
  6. commander = require("commander"),
  7. dsv = require("../");
  8. var program = path.basename(process.argv[1]),
  9. defaultInDelimiter = program.slice(0, 3) === "tsv" ? "\t" : ",";
  10. commander
  11. .version(require("../package.json").version)
  12. .usage("[options] [file]")
  13. .option("-o, --out <file>", "output file name; defaults to “-” for stdout", "-")
  14. .option("-r, --input-delimiter <character>", "input delimiter character", defaultInDelimiter)
  15. .option("-a, --auto-type", "parse rows with type inference (see d3.autoType)")
  16. .option("-n, --newline-delimited", "output newline-delimited JSON")
  17. .option("--input-encoding <encoding>", "input character encoding; defaults to “utf8”", "utf8")
  18. .option("--output-encoding <encoding>", "output character encoding; defaults to “utf8”", "utf8")
  19. .parse(process.argv);
  20. var inFormat = dsv.dsvFormat(commander.inputDelimiter);
  21. rw.readFile(commander.args[0] || "-", function(error, text) {
  22. if (error) throw error;
  23. var rowConverter = commander.autoType ? dsv.autoType : null
  24. var rows = inFormat.parse(iconv.decode(text, commander.inputEncoding), rowConverter);
  25. rw.writeFile(commander.out, iconv.encode(commander.newlineDelimited
  26. ? rows.map(function(row) { return JSON.stringify(row); }).join("\n") + "\n"
  27. : JSON.stringify(rows) + os.EOL, commander.outputEncoding), function(error) {
  28. if (error) throw error;
  29. });
  30. });