Skip to content

Latest commit

 

History

History
59 lines (54 loc) · 2.57 KB

README.md

File metadata and controls

59 lines (54 loc) · 2.57 KB

CSV-to-JSON-NodeJs

This repository contains a CSV parser that gets student infos, organize them and turn into an JSON file.

Some important things to note are:

1 - It was assumed that there is a pattern on the input of the groups

  • For example, the texts will always be "Classe n ", "Sala n", "Turma n" (n being a random number) or "Diurno"/"Noturno"/"Integral"
  • So if there is an different input, like "Disciplina SI198", the program will not recognize it as a group

2 - It was assumed that the phone numbers are always from Brazil

  • So they will be parsed and formated using the Brazilian patterns

3 - It was assumed that the only types of addresses are email and phone

  • So if there's another kind of input, for example 'whatsapp Pedagogical Responsible' it will not be recognized as an address

How to run the code

This program expects one CSV file as the "input.csv"

  • The CSV file must be in the same directory that "index.js"

The output of the program is an JSON file named "output.json"

To run the code you can open the directory where the project is located on your command prompt and run the next 2 commands:

npm install package.json
node index.js

For example:

C:\Users\user> cd C:\Users\user\Documents\Projects\CSV-to-JSON-NodeJs\
C:\Users\user\Documents\Projects\CSV-to-JSON-NodeJs> npm install package.json
C:\Users\user\Documents\Projects\CSV-to-JSON-NodeJs> node index.js

Logs

In the program execution, some logs will be shown in the command prompt

For example:

----------------------
Starting program, reading 'input.csv'
----------------------
Adding new student
----------------------
Invalid phone number: kkkkkkk / From person: John Appleseed / Tag:  [ 'Student' ]
----------------------
Adding info to already existent student, eid:  104 / Name:  John Appleseed
----------------------
Null email from person: John Appleseed / Tag:  [ 'Financial', 'Responsible' ]
----------------------
Null phone number from person: John Appleseed / Tag:  [ 'Financial', 'Responsible' ]
----------------------
Adding new student
----------------------
Null phone number from person: Mary Knight / Tag:  [ 'Pedagogical', 'Responsible' ]
----------------------
Null phone number from person: Mary Knight / Tag:  [ 'Financial', 'Responsible' ]
----------------------
Writing data in output.json
----------------------
Program finished

The logs can be used to see what is happening with some of the information

If the log "Program finished" appears, the execution went correctly, if it doesn't, some error happened