/pythonthesorimed

Interface python pour la base de donnée médicamenteuse thesorimed

Primary LanguagePythonOtherNOASSERTION

pythonthesorimed

https://travis-ci.org/jgirardet/pythonthesorimed.svg?branch=master Documentation Status Pypi package

Interface python pour thesorimed

Simple Interface Python pour utiliser l'api thesorimed compatible postgresql uniquement.

Features

  • Génère l'API python depuis le fichier thesormed api.sql
  • Fournit la class ThesoItem pour les appels à la base

Installation

pipenv install pythonthesorimed
ou
pip install pythonthesorimed

Usage

Initialisation

from pythonthesorimed.thesoitem import ThesoItem
session = ThesoItem(host, base, user, password)

Utilisation des API thesorimed

result = session.proc('api_name', param1, param2, param3)

Le retour est un Record ou un liste de Record. Record est un object possédant comme attribut les colonnes associées à la requète

par exemple :

>>> session.proc('get_the_gen_equiv', 3, 1)
    [Record(gsp_nom='RIFADINE 300MG GELULE', sp_code_equiv=4793, lib_virt='Rifampicine 300 mg gelule', sp_param='RIMACTAN 300MG GELULE', sp_code_sq_pk=3),
    Record(gsp_nom='RIMACTAN 300MG GELULE', sp_code_equiv=3, lib_virt='Rifampicine 300 mg gelule', sp_param='RIMACTAN 300MG GELULE', sp_code_sq_pk=3)]

    >>> result[0].gsp_nom
    'RIFADINE 300MG GELULE'

Fuzzy Search

Recheche par nom de tous les groupes de spécialités (gsp) et spécialités selon le motif proposé. L'idée est d'épurer un maximum les résutlats afin d'éviter tous les doublons dus notement aux différents laboratoires de génériques. le principe est les suivant :

  • Tout d'abord on récupère les gsp correspondant au motif
  • Puis on récupère les spécialités qui sont triées la maniière suivante:
    • On retire les spécialités appartenant à des gsp déjà sélectionnés.
    • Pour les spécialités restantes ayant un gsp commun, une seul est conservée
    • Les spécialités sans gsp sont conservées par défault pour ne pas risquer d'avoir un manque.
  • Le tout est retournée en une seule liste, d'abord les gsp puis les spécialités restantes. Le contenu de la liste est des dict au format : nom, cip, code, gsp_code.

Les différents éléments de la requète sont séparés par un espace et doivent être l'ordre de l'appelation officiele. Par exemple : "codéine paracétamol" ne retournera pas "paracétamol + codéine".

La recherche doit s'effectuer en minuscule.

session.fuzzy('chaine')

Parseur

Cloner le dépot puis :

make dev
pr python build.py path/to/api.sql

api.py est maintenant dans pythonthesorimed

Testing

make test : toutes les fonctionnalitées ne nécessitant pas le base de donnée thesorimed.

make test-local : tests avec des appels à thesorimed.

make all : tout.

Travis utilise la version "make test" d'où le coverage plus faible

Coverage

make test-coverage

make test-coverage-all