mirror of
https://github.com/denoland/std.git
synced 2024-11-21 20:50:22 +00:00
108 lines
2.7 KiB
TypeScript
108 lines
2.7 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
// This module is browser compatible.
|
|
import { stringify } from "./stringify.ts";
|
|
|
|
/** Options for {@linkcode CsvStringifyStream}. */
|
|
export interface CsvStringifyStreamOptions {
|
|
/**
|
|
* Delimiter used to separate values.
|
|
*
|
|
* @default {","}
|
|
*/
|
|
readonly separator?: string;
|
|
|
|
/**
|
|
* A list of columns to be included in the output.
|
|
*
|
|
* If you want to stream objects, this option is required.
|
|
*/
|
|
readonly columns?: Array<string>;
|
|
}
|
|
|
|
/**
|
|
* Convert each chunk to a CSV record.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-assert
|
|
* import { CsvStringifyStream } from "@std/csv/csv-stringify-stream";
|
|
*
|
|
* const path = await Deno.makeTempFile();
|
|
*
|
|
* const file = await Deno.open(path, { create: true, write: true });
|
|
* const readable = ReadableStream.from([
|
|
* { id: 1, name: "one" },
|
|
* { id: 2, name: "two" },
|
|
* { id: 3, name: "three" },
|
|
* ]);
|
|
*
|
|
* await readable
|
|
* .pipeThrough(new CsvStringifyStream({ columns: ["id", "name"] }))
|
|
* .pipeThrough(new TextEncoderStream())
|
|
* .pipeTo(file.writable);
|
|
* ```
|
|
*
|
|
* @typeParam TOptions The type of options for the stream.
|
|
*/
|
|
export class CsvStringifyStream<TOptions extends CsvStringifyStreamOptions>
|
|
extends TransformStream<
|
|
TOptions["columns"] extends Array<string> ? Record<string, unknown>
|
|
: Array<unknown>,
|
|
string
|
|
> {
|
|
/**
|
|
* Construct a new instance.
|
|
*
|
|
* @example Usage
|
|
* ```ts no-assert
|
|
* import { CsvStringifyStream } from "@std/csv/csv-stringify-stream";
|
|
*
|
|
* const path = await Deno.makeTempFile();
|
|
*
|
|
* const file = await Deno.open(path, { create: true, write: true });
|
|
* const readable = ReadableStream.from([
|
|
* { id: 1, name: "one" },
|
|
* { id: 2, name: "two" },
|
|
* { id: 3, name: "three" },
|
|
* ]);
|
|
*
|
|
* await readable
|
|
* .pipeThrough(new CsvStringifyStream({ columns: ["id", "name"] }))
|
|
* .pipeThrough(new TextEncoderStream())
|
|
* .pipeTo(file.writable);
|
|
* ```
|
|
*
|
|
* @param options Options for the stream.
|
|
*/
|
|
constructor(options?: TOptions) {
|
|
const {
|
|
separator,
|
|
columns = [],
|
|
} = options ?? {};
|
|
|
|
super(
|
|
{
|
|
start(controller) {
|
|
if (columns && columns.length > 0) {
|
|
try {
|
|
controller.enqueue(
|
|
stringify([columns], { separator, headers: false }),
|
|
);
|
|
} catch (error) {
|
|
controller.error(error);
|
|
}
|
|
}
|
|
},
|
|
transform(chunk, controller) {
|
|
try {
|
|
controller.enqueue(
|
|
stringify([chunk], { separator, headers: false, columns }),
|
|
);
|
|
} catch (error) {
|
|
controller.error(error);
|
|
}
|
|
},
|
|
},
|
|
);
|
|
}
|
|
}
|