Skip to content
This repository has been archived by the owner on Jun 5, 2021. It is now read-only.

Latest commit

 

History

History
172 lines (131 loc) · 7.04 KB

readme.md

File metadata and controls

172 lines (131 loc) · 7.04 KB

BiblioISN

Projet archivé en accès libre

BiblioISN est un logiciel Python 3 de gestion de livres pour les établissements scolaires, écrit par Renaud-Dov DEVERS et Ysilde Capet-Virbel Il s'agit d'un projet scolaire en vue d'une épreuve du baccalauréat.

Installation

Utilisez le gestionnaire de paquets pip pour installer les modules nécéssaires au bon fonctionnement du logiciel :

pip install isbnlib

ISBNLIB est une biliothèque utilisé pour télécharger les méta-données des livres à partir de leur ISBN. Les données sont récupérées sur la base de données Google Books

Pour la première utilisation, l'administrateur doit exécuter le fichier d'initialisation (init).

Utilisation

Étudiants

Pour démarrer le logiciel, il faut exécuter le programme "eleve_app.py"

Capture d'écran d'une recherche

Dans l'onglet de gauche, les élèves peuvent lancer une recherche. Le moteur de recherche va chercher des correspondances partielles dans les titres et auteurs. Voir le module research.

Pour voir la fiche détaillé d'un livre, il suffit de cliquer dessus.

Capture d'écran d'une fiche

L'utilisateur peut voir la description du livre, plus d'autres informations.

  • Si le livre n'a pas encore été réservé, l'élève peut le prendre pour une durée (paramétrée par la documentaliste). Pour réserver le livre, il suffit de rentrer son nom et prénom.
  • Dans le cas contraire, le logiciel indiquera à quelle date le livre devrait être de nouveau disponible.

Fiche d'un livre réservé

Sur la page de recherche, une icône indique si le livre est actuellement emprunté.

Livre réservé


Documentalistes

Pour s'occuper de la gestion des livres, des emprunts, il faut exécuter Remarque : Il n'est pas possible actuellement d'avoir deux fois le même ISBN. Chaque livre ne peut être compatabilisé qu'une seule fois le programme "gestion_app.py" Gestion ISBN L'administrateur a juste besoin de l'ISBN. Il peut ensuite effectuer différentes actions :

Gestion ISBN

Ajouter un livre

  • Mode automatique (Via ISBNLIB)

Ajout livre

Le module ISBNLIB va trouver les informations exisantes disponible sur Google Books.

Étant donné que le logiciel va télécharger les métadonnées en ligne, une connexion internet est obligatoire pour pouvoir rajouter un livre en local

  • Mode Manuel

Le mode Manuel n'a pas encore été implenté dans la version actuelle (1.00)

Le mode manuel permet de rentrer manuelement les données d'un livre.

Le mode manuel ne requiert pas de connexion internet. De même, les images de couverture sont automatiquement redimensionnées.

Remarque : Il n'est pas possible actuellement d'avoir deux fois le même ISBN. Chaque livre ne peut être compatabilisé qu'une seule fois

Retourne une erreur si le livre est déjà dans la base de données.

Supprimer un livre

L'administrateur peut retirer le livre de la base de donnée.

Retourne une erreur si le livre n'est pas dans la base de données

Modifier un livre

L'administrateur peut modifier un livre de la base de donnée.

Interface non finalisée :

Gestion ISBN

Il est possible de modifier l'image de courverture. Les extensions compatibles sont le jpg et le png. Les images sont automatiquement redimensionnées et copiées dans le dossier image après confirmation.

Marquer un livre comme rendu

Gestion ISBN

Il suffit de cliquer sur de marquer le livre comme non rendu.

Bases de données

Les bases de données sont crées en Json. Se trouvant dans le répertoire "/data", on y trouve de multiples bases de données listées ci dessous.

Titres

Ce fichier json permet de lister en une seule base de donnée les titres.

    {
    "9782092555729": "Le th\u00e9or\u00e8me des Katherine",
    "9782092543085": "Nos \u00e9toiles contraires",
    "9782291072652": "Emily Dickinson: Complete Poems",
    "9782013230858": "Le Horla - Texte int\u00e9gral",
    "9782370210395": "Regarde les lumi\u00e8res mon amour",
    "9782226449757": "Miroir de nos peines"
    }

Auteurs

Ce fichier json permet de lister en une seule base de donnée les auteurs et leurs livres.

{   
    "9783540420576": ["Roger Godement"],
    "9783446240933": ["John Green"],
    "9780141355078": ["John Green"],
    "9782747056120": ["Mary Pope Osborne","Philippe Masson"]
}

Réservations

Ce fichier json permet de lister en une seule base de donnée tous les emprunts de livre, avec les informations suivantes :

  • Date d'emprunt
  • Date maximale où le livre doit être rendu
  • Nom de l'élève
{
    "9782203001022":{
        "from": "12/04/2020",
        "to": "26/04/2020",
        "Name": "Name1 Surname1"
    },
    "9788416588725":{
    "from": "21/04/2020",
    "to": "05/05/2020",
    "Name": "Name2 Surname2"
    }
}

Remarque : Le nombre maximum de livres pouvant être emprunté par un lecteur peut être modifié ou être désactivé. Par défaut, ce paramètre est défini sur 3.

Fiche livre

Chaque livre possède sa propre fiche détaillée situé dans "data/livres/{ISBN}.json".

Exemple d'une fiche de livre :

{
    "Book": {
        "Titre": "Harry Potter et le Prisonnier d'Azkaban",
        "Auteur": ["J.K. Rowling"],
        "Synopsis": "Sirius Black, le dangereux criminel qui s\u2019est \u00e9chapp\u00e9 de la forteresse d\u2019Azkaban, recherche Harry Potter. C\u2019est donc sous bonne garde que l\u2019apprenti sorcier fait sa troisi\u00e8me rentr\u00e9e. Au programme : des cours de divination, la fabrication d\u2019une potion de Ratatinage, le dressage des hippogriffes...",
        "publisher": "Pottermore Publishing",
        "year": "2015",
        "language": "fr",
        "img": "img/9781781101056.jpg",
        "added": "22/02/2020",
        "taken": false
    },
    "Notes": {"1": 2,"2": 4,"3": 4,"4": 3,"5": 3}
}

Les fiches contiennent les informations suivantes :

  • Titre du livre
  • Auteur(s)
  • Description (Synopsis)
  • Editeur
  • Année de publication
  • Langage
  • Date d'ajout
  • Chemin d'accès à l'image
  • "taken" :
    • False : le livre n'a pas été emprunté
    • True : le livre a été emprunté

Il contient également une liste des notes émises par les utilisateurs.