Bases des données JSON avec Tablesaw

Importer des données en Java

Anthony Markham

VP Quant Developer

Introduction au JSON

  • JSON : JavaScript Object Notation
    • Format léger d'échange de données
    • Format standard pour les API Web
    • Structure en paires clé-valeur

image json.jpg

Importer des données en Java

Données tabulaires

  • Lignes et colonnes fixes
  • Tabulaire : Types de données uniformes
| Nom   | Âge | Ville   |
|-------|-----|---------|
| Alice | 30  | Boston  |
| Bob   | 25  | Seattle |

JSON

  • Structures imbriquées flexibles
  • Types de données mixtes et hiérarchies
[
  {"name": "Alice", 
      "age": 30, 
      "address": {"city": "Boston", 
                  "state": "MA"}},
  {"name": "Bob", 
      "age": 25, 
      "address": {"city": "Seattle", 
                  "state": "WA"}}
]
Importer des données en Java

Lecture de JSON

  • Utiliser uniquement pour des fichiers JSON simples
// Méthode simple pour lire un fichier JSON
Table products = Table.read().file("products.json");

$$

import tech.tablesaw.io.json.JsonReader;
import tech.tablesaw.io.json.JsonReadOptions;
  • Offre des configurations supplémentaires
// Lecture d'un fichier JSON avec JsonReadOptions
JsonReadOptions options = JsonReadOptions.builder("products.json").build();

Table products = new JsonReader().read(options);
Importer des données en Java

Accès aux données JSON

  • Méthodes Tablesaw familières fonctionnent
// Accéder aux colonnes des données JSON
StringColumn names = table.stringColumn("name");
DoubleColumn prices = table.doubleColumn("price");

// Effectuer des calculs double avgPrice = prices.mean(); String mostExpensive = table .where(prices.isEqualTo(prices.max())) .stringColumn("name").get(0);
Importer des données en Java

Bonnes pratiques JSON - validation

  • Valider la structure JSON avant traitement
// Validation et gestion des erreurs
try {
    JsonReadOptions options = JsonReadOptions.builder("data.json").build();
    Table data = new JsonReader().read(options);
    if (data.rowCount() > 0) {
        // Traiter les données
    }
} catch (Exception e) {
    System.err.println("Erreur de lecture JSON : " + e.getMessage());
}
if (data.rowCount() == 100) {
    System.out.println("La table a exactement 100 lignes - traitement des données");
}
Importer des données en Java

Bonnes pratiques JSON - valeurs manquantes

  • Gérer les valeurs manquantes/nulles
// Supprimer les lignes avec des valeurs manquantes
data = data.dropRowsWithMissingValues();
  • Adapter les types de données aux besoins d'analyse
// Convertir une colonne entière en double pour les calculs
data = data.replaceColumn("price", data.intColumn("price").asDoubleColumn());
Importer des données en Java

Passons à la pratique !

Importer des données en Java

Preparing Video For Download...