mirror of
https://github.com/zhigang1992/DefinitelyTyped.git
synced 2026-04-23 04:49:15 +08:00
360 lines
20 KiB
TypeScript
360 lines
20 KiB
TypeScript
// Type definitions for D3JS d3-dsv module 1.0
|
|
// Project: https://github.com/d3/d3-dsv/
|
|
// Definitions by: Tom Wanzek <https://github.com/tomwanzek>, Alex Ford <https://github.com/gustavderdrache>, Boris Yankov <https://github.com/borisyankov>
|
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
|
|
|
// Last module patch version validated against: 1.0.8
|
|
|
|
// ------------------------------------------------------------------------------------------
|
|
// Shared Types and Interfaces
|
|
// ------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
* An object representing a DSV parsed row with values represented as strings.
|
|
*/
|
|
export interface DSVRowString {
|
|
[key: string]: string | undefined;
|
|
}
|
|
|
|
/**
|
|
* An object representing a DSV parsed row with values represented as an arbitrary datatype, depending
|
|
* on the performed parsed row mapping.
|
|
*/
|
|
export interface DSVRowAny {
|
|
[key: string]: any;
|
|
}
|
|
|
|
/**
|
|
* An array object representing all parsed rows. The array is enhanced with a property listing
|
|
* the names of the parsed columns.
|
|
*/
|
|
export interface DSVParsedArray<T> extends Array<T> {
|
|
/**
|
|
* List of column names.
|
|
*/
|
|
columns: string[];
|
|
}
|
|
|
|
// ------------------------------------------------------------------------------------------
|
|
// CSV Parsers and Formatters
|
|
// ------------------------------------------------------------------------------------------
|
|
|
|
// csvParse(...) ============================================================================
|
|
|
|
/**
|
|
* Parses the specified string, which must be in the comma-separated values format, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike csvParseRows, this method requires that the first line of the CSV content contains a comma-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* Equivalent to dsvFormat(",").parse.
|
|
*
|
|
* @param csvString A string, which must be in the comma-separated values format.
|
|
*/
|
|
export function csvParse(csvString: string): DSVParsedArray<DSVRowString>;
|
|
/**
|
|
* Parses the specified string, which must be in the comma-separated values format, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike csvParseRows, this method requires that the first line of the CSV content contains a comma-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* Equivalent to dsvFormat(",").parse.
|
|
*
|
|
* @param csvString A string, which must be in the comma-separated values format.
|
|
* @param row A row conversion function which is invoked for each row, being passed an object representing the current row (d),
|
|
* the index (i) starting at zero for the first non-header row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
export function csvParse<ParsedRow extends DSVRowAny>(
|
|
csvString: string,
|
|
row: (rawRow: DSVRowString, index: number, columns: string[]) => ParsedRow | undefined | null
|
|
): DSVParsedArray<ParsedRow>;
|
|
|
|
// csvParseRows(...) ========================================================================
|
|
|
|
/**
|
|
* Parses the specified string, which must be in the comma-separated values format, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike csvParse, this method treats the header line as a standard row, and should be used whenever CSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* If a row conversion function is not specified, field values are strings. For safety, there is no automatic conversion to numbers, dates, or other types.
|
|
* In some cases, JavaScript may coerce strings to numbers for you automatically (for example, using the + operator), but better is to specify a row conversion function.
|
|
*
|
|
* Equivalent to dsvFormat(",").parseRows.
|
|
*
|
|
* @param csvString A string, which must be in the comma-separated values format.
|
|
*/
|
|
export function csvParseRows(csvString: string): string[][];
|
|
/**
|
|
* Parses the specified string, which must be in the comma-separated values format, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike csvParse, this method treats the header line as a standard row, and should be used whenever CSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* Equivalent to dsvFormat(",").parseRows.
|
|
*
|
|
* @param csvString A string, which must be in the comma-separated values format.
|
|
* @param row A row conversion function which is invoked for each row, being passed an array representing the current row (d), the index (i)
|
|
* starting at zero for the first row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
export function csvParseRows<ParsedRow extends DSVRowAny>(
|
|
csvString: string,
|
|
row: (rawRow: string[], index: number) => ParsedRow | undefined | null
|
|
): ParsedRow[];
|
|
|
|
// csvFormat(...) ============================================================================
|
|
|
|
/**
|
|
* Formats the specified array of object rows as comma-separated values, returning a string.
|
|
* This operation is the inverse of csvParse. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the comma-delimiter.
|
|
* Values that contain either the comma-delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* If columns is not specified, the list of column names that forms the header row is determined by the union of all properties on all objects in rows;
|
|
* the order of columns is nondeterministic.
|
|
*
|
|
* Equivalent to dsvFormat(",").format.
|
|
*
|
|
* @param rows Array of object rows.
|
|
* @param columns An array of strings representing the column names.
|
|
*/
|
|
export function csvFormat(rows: DSVRowAny[], columns?: string[]): string;
|
|
|
|
// csvFormatRows(...) ========================================================================
|
|
|
|
/**
|
|
* Formats the specified array of array of string rows as comma-separated values, returning a string.
|
|
* This operation is the reverse of csvParseRows. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the comma-delimiter.
|
|
* Values that contain either the comma-delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* To convert an array of objects to an array of arrays while explicitly specifying the columns, use array.map.
|
|
* If you like, you can also array.concat this result with an array of column names to generate the first row.
|
|
*
|
|
* Equivalent to dsvFormat(",").formatRows.
|
|
*
|
|
* @param rows An array of array of string rows.
|
|
*/
|
|
export function csvFormatRows(rows: string[][]): string;
|
|
|
|
// ------------------------------------------------------------------------------------------
|
|
// TSV Parsers and Formatters
|
|
// ------------------------------------------------------------------------------------------
|
|
|
|
// tsvParse(...) ============================================================================
|
|
|
|
/**
|
|
* Parses the specified string, which must be in the tab-separated values format, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike tsvParseRows, this method requires that the first line of the TSV content contains a tab-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* Equivalent to dsvFormat("\t").parse.
|
|
*
|
|
* @param tsvString A string, which must be in the tab-separated values format.
|
|
*/
|
|
export function tsvParse(tsvString: string): DSVParsedArray<DSVRowString>;
|
|
/**
|
|
* Parses the specified string, which must be in the tab-separated values format, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike tsvParseRows, this method requires that the first line of the TSV content contains a tab-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* Equivalent to dsvFormat("\t").parse.
|
|
*
|
|
* @param tsvString A string, which must be in the tab-separated values format.
|
|
* @param row A row conversion function which is invoked for each row, being passed an object representing the current row (d),
|
|
* the index (i) starting at zero for the first non-header row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
export function tsvParse<MappedRow extends DSVRowAny>(
|
|
tsvString: string,
|
|
row: (rawRow: DSVRowString, index: number, columns: string[]) => MappedRow | undefined | null
|
|
): DSVParsedArray<MappedRow>;
|
|
|
|
// tsvParseRows(...) ========================================================================
|
|
|
|
/**
|
|
* Parses the specified string, which must be in the tab-separated values format, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike tsvParse, this method treats the header line as a standard row, and should be used whenever TSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* If a row conversion function is not specified, field values are strings. For safety, there is no automatic conversion to numbers, dates, or other types.
|
|
* In some cases, JavaScript may coerce strings to numbers for you automatically (for example, using the + operator), but better is to specify a row conversion function.
|
|
*
|
|
* Equivalent to dsvFormat("\t").parseRows.
|
|
*
|
|
* @param tsvString A string, which must be in the tab-separated values format.
|
|
*/
|
|
export function tsvParseRows(tsvString: string): string[][];
|
|
/**
|
|
* Parses the specified string, which must be in the tab-separated values format, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike tsvParse, this method treats the header line as a standard row, and should be used whenever TSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* Equivalent to dsvFormat("\t").parseRows.
|
|
*
|
|
* @param tsvString A string, which must be in the tab-separated values format.
|
|
* @param row A row conversion function which is invoked for each row, being passed an array representing the current row (d), the index (i)
|
|
* starting at zero for the first row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
export function tsvParseRows<MappedRow extends DSVRowAny>(
|
|
tsvString: string,
|
|
row: (rawRow: string[], index: number) => MappedRow | undefined | null
|
|
): MappedRow[];
|
|
|
|
// tsvFormat(...) ============================================================================
|
|
|
|
/**
|
|
* Formats the specified array of object rows as tab-separated values, returning a string.
|
|
* This operation is the inverse of tsvParse. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the tab-delimiter.
|
|
* Values that contain either the tab-delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* If columns is not specified, the list of column names that forms the header row is determined by the union of all properties on all objects in rows;
|
|
* the order of columns is nondeterministic.
|
|
*
|
|
* Equivalent to dsvFormat("\t").format.
|
|
*
|
|
* @param rows Array of object rows.
|
|
* @param columns An array of strings representing the column names.
|
|
*/
|
|
export function tsvFormat(rows: DSVRowAny[], columns?: string[]): string;
|
|
|
|
// tsvFormatRows(...) ========================================================================
|
|
|
|
/**
|
|
* Formats the specified array of array of string rows as tab-separated values, returning a string.
|
|
* This operation is the reverse of tsvParseRows. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the tab-delimiter.
|
|
* Values that contain either the tab-delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* To convert an array of objects to an array of arrays while explicitly specifying the columns, use array.map.
|
|
* If you like, you can also array.concat this result with an array of column names to generate the first row.
|
|
*
|
|
* Equivalent to dsvFormat("\t").formatRows.
|
|
*
|
|
* @param rows An array of array of string rows.
|
|
*/
|
|
export function tsvFormatRows(rows: string[][]): string;
|
|
|
|
// ------------------------------------------------------------------------------------------
|
|
// DSV Generalized Parsers and Formatters
|
|
// ------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
* A DSV parser and formatter
|
|
*/
|
|
export interface DSV {
|
|
/**
|
|
* Parses the specified string, which must be in the delimiter-separated values format with the appropriate delimiter, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike dsv.parseRows, this method requires that the first line of the DSV content contains a delimiter-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* @param dsvString A string, which must be in the delimiter-separated values format with the appropriate delimiter.
|
|
*/
|
|
parse(dsvString: string): DSVParsedArray<DSVRowString>;
|
|
/**
|
|
* Parses the specified string, which must be in the delimiter-separated values format with the appropriate delimiter, returning an array of objects representing the parsed rows.
|
|
*
|
|
* Unlike dsv.parseRows, this method requires that the first line of the DSV content contains a delimiter-separated list of column names;
|
|
* these column names become the attributes on the returned objects.
|
|
*
|
|
* The returned array also exposes a columns property containing the column names in input order (in contrast to Object.keys, whose iteration order is arbitrary).
|
|
*
|
|
* @param dsvString A string, which must be in the delimiter-separated values format with the appropriate delimiter.
|
|
* @param row A row conversion function which is invoked for each row, being passed an object representing the current row (d),
|
|
* the index (i) starting at zero for the first non-header row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
parse<ParsedRow extends DSVRowAny>(
|
|
dsvString: string,
|
|
row: (rawRow: DSVRowString, index: number, columns: string[]) => ParsedRow | undefined | null
|
|
): DSVParsedArray<ParsedRow>;
|
|
|
|
/**
|
|
* Parses the specified string, which must be in the delimiter-separated values format with the appropriate delimiter, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike dsv.parse, this method treats the header line as a standard row, and should be used whenever DSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* If a row conversion function is not specified, field values are strings. For safety, there is no automatic conversion to numbers, dates, or other types.
|
|
* In some cases, JavaScript may coerce strings to numbers for you automatically (for example, using the + operator), but better is to specify a row conversion function.
|
|
*
|
|
* @param dsvString A string, which must be in the delimiter-separated values format with the appropriate delimiter.
|
|
*/
|
|
parseRows(dsvString: string): string[][];
|
|
/**
|
|
* Parses the specified string, which must be in the delimiter-separated values format with the appropriate delimiter, returning an array of arrays representing the parsed rows.
|
|
*
|
|
* Unlike dsv.parse, this method treats the header line as a standard row, and should be used whenever DSV content does not contain a header.
|
|
* Each row is represented as an array rather than an object. Rows may have variable length.
|
|
*
|
|
* @param dsvString A string, which must be in the delimiter-separated values format with the appropriate delimiter.
|
|
* @param row A row conversion function which is invoked for each row, being passed an array representing the current row (d), the index (i)
|
|
* starting at zero for the first row, and the array of column names. If the returned value is null or undefined,
|
|
* the row is skipped and will be omitted from the array returned by dsv.parse; otherwise, the returned value defines the corresponding row object.
|
|
* In effect, row is similar to applying a map and filter operator to the returned rows.
|
|
*/
|
|
parseRows<ParsedRow extends DSVRowAny>(
|
|
dsvString: string,
|
|
row: (rawRow: string[], index: number) => ParsedRow | undefined | null
|
|
): ParsedRow[];
|
|
|
|
/**
|
|
* Formats the specified array of object rows as delimiter-separated values, returning a string.
|
|
* This operation is the inverse of dsv.parse. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the delimiter (such as a comma, ,).
|
|
* Values that contain either the delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* If columns is not specified, the list of column names that forms the header row is determined by the union of all properties on all objects in rows;
|
|
* the order of columns is nondeterministic.
|
|
*
|
|
* @param rows Array of object rows.
|
|
* @param columns An array of strings representing the column names.
|
|
*/
|
|
format(rows: DSVRowAny[], columns?: string[]): string;
|
|
|
|
/**
|
|
* Formats the specified array of array of string rows as delimiter-separated values, returning a string.
|
|
* This operation is the reverse of dsv.parseRows. Each row will be separated by a newline (\n),
|
|
* and each column within each row will be separated by the delimiter (such as a comma, ,).
|
|
* Values that contain either the delimiter, a double-quote (") or a newline will be escaped using double-quotes.
|
|
*
|
|
* To convert an array of objects to an array of arrays while explicitly specifying the columns, use array.map.
|
|
* If you like, you can also array.concat this result with an array of column names to generate the first row.
|
|
*
|
|
* @param rows An array of array of string rows.
|
|
*/
|
|
formatRows(rows: string[][]): string;
|
|
}
|
|
|
|
/**
|
|
* Constructs a new DSV parser and formatter for the specified delimiter.
|
|
*
|
|
* @param delimiter A delimiter character. The delimiter must be a single character (i.e., a single 16-bit code unit);
|
|
* so, ASCII delimiters are fine, but emoji delimiters are not.
|
|
*/
|
|
export function dsvFormat(delimiter: string): DSV;
|