- суммировать в несколько потоков простые числа от 1 до заданного N
- написать парсер для CSV
col1,col2,col3
r2 c1,r2 c2,r2 c3
"r3,c1","r3,c2","r3,c3"
"r4\",\"\\c1","r4\",\"c2","r4\",\"c3"
Должен получиться csvParser :: Parser [[String]]
.
В примере он должен вернуть
[["col1","col2","col3"],["r2 c1","r2 c2","r3 c3"],["r3,c1","r3,c2","r3,c3"],["r4\",\"\\c1","r4\",\"c2","r4\",\"c3"]]
- написать
sumAndTabulate
- взять данные из Our World in Data: https://github.com/owid/covid-19-data/blob/master/public/data/owid-covid-data.csv (данные отсортированы по странам и по датам)
- распарсить ежедневные случаи COVID-19 (new_cases_smoothed), ежедневные смерти (new_deaths_smoothed), ежедневные вакцинации (new_vaccinations_smoothed) и, собственно, страну (iso_code), континент (continent) и население (population). Достаточно парсить столбцы с нужными индексами
- записать эти данные в соответствующий тип данных
- просуммировать (в другой тип данных) и вывести на экран указанные данные, сгруппировав их по континенту и в целом по миру
- использовать streaming, streaming-attoparsec (для связи с парсингом csv), streaming-bytestring (для чтения данных из файла), lens (для доступа к компонентам типов данных)
- приготовить клиента для https://anapioficeandfire.com/, используя servant
- продемонстрировать работу, сделав несколько запросов в main