DEV Community

Cover image for Le plus rare des livres à disparu ! Saison 1 - Episode 1
Mary 🇪🇺 🇷🇴 🇫🇷
Mary 🇪🇺 🇷🇴 🇫🇷

Posted on

Le plus rare des livres à disparu ! Saison 1 - Episode 1

Dans la quiétude apparente de Digitown, une ombre planait sur la Bibliothèque Nationale, prête à dévoiler ses trésors culturels. La numérisation de 325 000 ouvrages rares était sur le point de rendre hommage aux explorateurs de cette cité paisible. Cependant, alors que l'excitation montait pour la réouverture de l'exposition, mais caprice du destin s'apprêtait à jeter une ombre sinistre sur les étagères prestigieuses de Digitown. Le live "De Revolutionibus Magnis Data" de Gustav Kustov, un des plus rare du monde, avait mystérieusement disparu.

Face à cette situation urgente, la mairesse, Mme Gaia Budskott, fit appel à l'agence de détectives Kusto, réputée pour résoudre les mystères les plus ardus. Un jeune détective, prêt à faire ses preuves, se voyait confier sa première mission : retrouver l’ouvrage disparu.

Les données numériques de la Bibliothèque Nationale de Digitown constituaient un labyrinthe complexe pour notre jeune détective. Alors que chaque livre était étiqueté d'un identifiant RFID unique, le livre de Kustov avait disparu en laissant derrière lui son identifiant sur le sol froid de la bibliothèque.

S'immergeant dans les méandres du système d'information, le détective commença son enquête.


.execute database script <|
// Create table for the books
.create-merge table Books(rf_id:string, book_title: "string, publish_date:long, author:string, language:string, number_of_pages:long, weight_gram:long)"
//clear any previously ingested data if such exists
.clear table Books data
// Import data for books
// (Used data is utilizing catalogue from https://github.com/internetarchive/openlibrary )
.ingest into table Books ('https://kustodetectiveagency.blob.core.windows.net/digitown-books/books.csv.gz') with (ignoreFirstRecord=true)
// Create table for the shelves
.create-merge table Shelves (shelf:long, rf_ids:dynamic, total_weight:long) 
.clear table Shelves data
// Import data for shelves
.ingest into table Shelves ('https://kustodetectiveagency.blob.core.windows.net/digitown-books/shelves.csv.gz') with (ignoreFirstRecord=true)
Enter fullscreen mode Exit fullscreen mode

Les étagères numériques envoyaient des données constantes, sur les livres présents. Un défi monumental s'offrait à lui : retrouver une aiguille dans une bibliothèque de données numériques.

Il commenca une analyse minutieuse d’une seul et unique étagère.


Shelves
| where shelf == "1395"
Enter fullscreen mode Exit fullscreen mode

Result of kusto data


Mais brut, les données ne pouvaient pas être exploite, il ce mit d'abord a isoler chaque identifiant RFID


Shelves
| where shelf == "1395"
| mv-expand rf_ids to typeof(string)
Enter fullscreen mode Exit fullscreen mode

Result of kusto data


Il etait maintenant possible de relier cela aux informations spécifiques de chaque livre. Le poids des livres, comparés aux poids enregistrés par les étagères, semblaient cohérents malgré de légères variations. Un détail minime dans l'équation, ou bien une pièce manquante au puzzle ?


Shelves
| mv-expand rf_ids to typeof(string)
| join kind=inner (Books) on $left.rf_ids == $right.rf_id
| summarize TotalWeightBook = sum(weight_gram) by shelf
| join kind=inner (Shelves) on shelf
| project shelf, TotalWeightBook, total_weight
Enter fullscreen mode Exit fullscreen mode

Result of kusto data


L'idée jaillit soudainement dans l'esprit du jeune détective. Et si il calculait avec précision la différence en pourcentage entre le poids total des livres par étagère et le poids enregistré par l'étagère elle même.


Shelves
| mv-expand rf_ids to typeof(string)
| join kind=inner (Books) on $left.rf_ids == $right.rf_id
| summarize TotalWeightBook = sum(weight_gram) by shelf
| join kind=inner (Shelves) on shelf
| project shelf, TotalWeightBook, total_weight
| extend WeightVariation = round((todouble(total_weight) - TotalWeightBook) / TotalWeightBook * 100,3)
| top 10 by WeightVariation
Enter fullscreen mode Exit fullscreen mode

Result of kusto data


Une étagère se détacha nettement du lot : l'étagère numéro 4 242. Un frisson d'excitation illumina le visage du détective, laissant présager une découverte imminente, persuadé d'avoir déniché l'endroit où se cachait le précieux "De Revolutionibus Magnis Data".

La tension monta alors qu'il se dirigea vers l'étagère cible. Et là, entre des volumes ordinaires, reposait le livre tant recherché. Le mystère était résolu, le détective avait triomphé.

La directrice de la bibliothèque exprima un soulagement sincère, remerciant le jeune détective pour son efficacité.

La ville de Digitown célébra cette journée mémorable, et le détective novice, qui avait commencé cette enquête avec une pointe d'appréhension, s'imposa comme un véritable détective, prouvant que persévérance, intelligence et analyse de données étaient les clés de la résolution des énigmes.

Ainsi se conclut notre histoire, révélant que même les mystères les plus insaisissables peuvent être résolus avec ténacité. L'avenir réserve-t-il d'autres défis à notre détective ? Seul le temps le nous le dira.


Reward to have solved the case


Billboard image

Use Playwright to test. Use Playwright to monitor.

Join Vercel, CrowdStrike, and thousands of other teams that run end-to-end monitors on Checkly's programmable monitoring platform.

Get started now!

Top comments (0)

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

👋 Kindness is contagious

Engage with a sea of insights in this enlightening article, highly esteemed within the encouraging DEV Community. Programmers of every skill level are invited to participate and enrich our shared knowledge.

A simple "thank you" can uplift someone's spirits. Express your appreciation in the comments section!

On DEV, sharing knowledge smooths our journey and strengthens our community bonds. Found this useful? A brief thank you to the author can mean a lot.

Okay