Imagine something like this:

neoCSVReader := (NeoCSVReader on: stream).
neoCSVReader
separator: $,;
recordClass: PriceRecord;
addIgnoredField; "<name>"
addField:  #securityUniqueId: ; "<ticker>"
addField: #date: converter: [ :string | Date readFrom: string readStream
pattern: 'yyyymmdd' ]; "<date>"
addFloatField: #open: ; "<open>"
addFloatField: #high: ; "<high>"
addFloatField: #low: ; "<low>"
addFloatField: #close: ; "<close>"
addIntegerField: #volume: . "<vol>"
neoCSVReader skipHeader.
priceRecords := neoCSVReader upToEnd.


The #recordClass: is optional. If not, you can get an array of arrays
instead.
You can add #addIgnoredField for all the ones you want to ignore, then add
the #addNumber: etc for the number ones, etc. To write a default empty
value, I would use my own converter. Something like:

addField: #stringcolumn: converter: [ :string | string isEmptyOrNil ifTrue:
[ '' ]  ];
addField: #numbercolumn: converter: [ :string | string isEmptyOrNil ifTrue:
[ 0 ] ifFalse: [ NeoNumberParser parse: string ]  ];

Hope this helps.

Cheers,



On Mon, Sep 28, 2015 at 9:06 AM, Nicolai Hess <nicolaih...@web.de> wrote:

> Hi,
>
> I have two problems I could not solve:
>
> 1. I would like to read only some columns: I have a large file with
>     ~30 colums, but I am only interested on ~5 columns
>     (not that important, I could pre-process the file) but anyway it would
> be
>     nice to do it in smalltalk.
>
> 2. some columns will contain only strings (quoted values) and some only
> numbers,
>     but the field may be empty, is it possible to define the default
> "emptyValue" as an
>     - empty string for empty fields in the "string column"
>     - 0 for empty fields in the "number column"?
>
>
> thanks
>  in advance
>
> nicolai
>



-- 
Mariano
http://marianopeck.wordpress.com

Reply via email to