2.0.0 • Published 1 year ago

@pedroentringer/cheerio-table-parser v2.0.0

Weekly downloads
1
License
MIT
Repository
github
Last release
1 year ago

Cheerio Table Parser

Usado para converter tabelas em HTML para JSON

Como usar

Para iniciar você precisará instalar a lib cheerio

yarn add cheerio @pedroentringer/cheerio-table-parser

Feito isso basta iniciar as duas libs e fazer o scrapping

import { parseTable } from '@pedroentringer/cheerio-table-parser';

const html =
  '<table id="tabela"><thead><tr><th>id</th><th>nome</th><th>Data de Nascimento</th><th>idade</th></tr></thead><tbody><tr><td>1</td><td>Pedro Entringer</td><td>05/10/1997</td><td>22</td></tr></tbody></table>';

const table = parseTable(html);

O resultado sera:

[
  {
    "id": 1,
    "nome": "Pedro Entringer",
    "dataDeNascimento": "05/10/1997",
    "idade": 22
  }
]

Conversão automatica de tipos

O Script convert para String, Number e Boolean

Tabela sem thead

Se sua tabela não tiver os campos em thead, você pode usar a configuração headerIsFirstLine.

import { parseTable } from '@pedroentringer/cheerio-table-parser';

const html =
  '<table id="tabela"><tbody><tr><th>id</th><th>nome</th><th>Data de Nascimento</th><th>idade</th></tr><tr><td>1</td><td>Pedro Entringer</td><td>05/10/1997</td><td>22</td></tr></tbody></table>';

const table = parseTable(html, { headerIsFirstLine: true });

O resultado sera:

[
  {
    "id": 1,
    "nome": "Pedro Entringer",
    "dataDeNascimento": "05/10/1997",
    "idade": 22
  }
]

Header customizado

Se sua tabela não tiver header, você poderá definir manualmente usando a configuração headers.

import { parseTable } from '@pedroentringer/cheerio-table-parser';

const html =
  '<table id="tabela"><tbody><tr><td>1</td><td>Pedro Entringer</td><td>05/10/1997</td><td>22</td></tr></tbody></table>';

const table = parseTable(html, { headers: ["id", "nome", "dataDeNascimento", "idade"] });

O resultado sera:

[
  {
    "id": 1,
    "nome": "Pedro Entringer",
    "dataDeNascimento": "05/10/1997",
    "idade": 22
  }
]
1.0.7

1 year ago

1.0.6

1 year ago

1.0.5

1 year ago

1.0.4

1 year ago

2.0.0

1 year ago

1.0.3

3 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago