module Data.TimeSeries.CSVReader
( load
)where
import qualified Data.ByteString.Lazy as BS
import qualified Data.Text as T
import Data.Csv
import qualified Data.Vector as V
import Data.Time (UTCTime)
import Data.TimeSeries.Series ( Series
, emptySeries
, series
)
load :: (T.Text -> UTCTime) -> FilePath -> IO Series
load ft filePath = do
csvData <- BS.readFile filePath
case decode HasHeader csvData of
Left err -> do
_ <- putStrLn err
return emptySeries
Right vs -> do
let vs' = V.map (parseLine ft) vs
return $ series (V.toList vs')
parseLine :: (T.Text -> UTCTime) -> (T.Text, Double) -> (UTCTime, Double)
parseLine ft (date, value) = (ft date, value)