CSV(2) CSV(2) NAME csv - comma-separated values SYNOPSIS include "bufio.m"; include "csv.m"; csv := load CSV CSV->PATH; init: fn(bufio: Bufio); getline: fn(fd: ref Bufio->Iobuf): list of string; quote: fn(s: string): string; DESCRIPTION CSV provides a few functions to help read and write data in ``comma-separated value'' format. The csv format has a sequence of fields on a line (terminated by a newline, car- riage return, or carriage return and newline). Fields are separated by commas, and may be empty. A field that starts with a double-quote is a quoted field, continuing to the next lone double-quote character, including commas and line terminators, but taking two double-quotes to represent one double-quote. Any text following quoted text, up to the next comma or line terminator, is included in the field value. Note that in a field that does not start with a double-quote, double-quotes are not treated specially. Init must be called before any other operation of the mod- ule. Bufio is the instance of the bufio(2) module that will provide the open files to be read. Getline reads a sequence of fields in csv format from Iobuf fd, unquotes fields as required, and returns them in order in a list. It returns nil on end-of-file (or read error). An empty line is regarded as containing a single empty field. Quote returns string s quoted as required by the csv format: the result is quoted if s contains comma, newline, or a quote (and all embedded quotes are doubled). SOURCE /appl/lib/csv.b SEE ALSO sh-csv(1) Page 1 Plan 9 (printed 1/3/25)