3.22 data-source
Accordingly, Pyret exposes a CellContent data type to record what type it thinks each cell contains, and a Sanitizer to allow enforcing a uniform type over all values in a column. These two notions are used by the gdrive-sheets library to convert Google Sheets files into Pyret Tables. A similar library could be written to use these two types to load tables from .csv files or other data sources.
3.22.1 The CellContent Type
This datatype describes Pyret’s
3.22.2 Sanitizers
3.22.2.1 Pre-defined sanitizers
- string-sanitizer :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> String
This sanitizer tries to convert CellContents containing anything to a String, by calling tostring on it.
- num-sanitizer :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Number
This sanitizer tries to convert CellContents containing numbers, strings, or booleans to a Number. Strings are attempted to be parsed. True and false convert to 1 and 0 respectively. Any other values are rejected, including blank cells.
- bool-sanitizer :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Boolean
This sanitizer tries to convert CellContents containing numbers, strings, or booleans to a Boolean. 0 and 1 convert to false and true respectively. The (case-insensitive) strings "true" and "false" convert appropriately. Any other values are rejected, including blank cells.
- strict-num-sanitizer :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Number
This sanitizer tries to convert CellContents containing strings or numbers to a Number. Strings are attempted to be parsed. Any other values are rejected, including blank cells.
- strings-only :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> String
This sanitizer accepts CellContents containing strings only, and rejects all other values, including blank cells.
- booleans-only :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Boolean
This sanitizer accepts CellContents containing booleans only, and rejects all other values, including blank cells.
- numbers-only :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Number
This sanitizer accepts CellContents containing numbers only, and rejects all other values, including blank cells.
- empty-only :: (
- x :: CellContent<A>,
- col :: Number,
- row :: Number
- )
- -> Option<A>
This sanitizer accepts CellContents containing blank cells only, and rejects all other values.
- option-sanitizer :: (
- value-sanitizer :: Sanitizer<A>
- )
- -> Sanitizer<Option<A>>
This higher-order sanitizer takes in another sanitizer that does not expect to be given blank cells, and produces a new sanitizer that can accept them. Blank cells are converted to none, while valid non-blank cells are converted to a some value containing the converted contents of the cell. Values rejected by the value-sanitizer are rejected by this sanitizer as well.
This sanitizer is useful for handling incomplete data that might contain blank values; a subsequent processing step could filter out the none values.