Skip to main content

Une interface python avec la base médicamenteuse thesorimed

Project description

===============================
pythonthesorimed
===============================

.. image:: https://travis-ci.org/jgirardet/pythonthesorimed.svg?branch=master
:target: https://travis-ci.org/jgirardet/pythonthesorimed
.. image:: https://readthedocs.org/projects/pythonthesorimed/badge/?version=latest
:target: http://pythonthesorimed.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Status
.. image:: https://coveralls.io/repos/github/jgirardet/pythonthesorimed/badge.svg
:target: https://coveralls.io/github/jgirardet/pythonthesorimed
.. image:: https://badge.fury.io/py/pythonthesorimed.svg
:target: https://pypi.python.org/pypi/pythonthesorimed/
:alt: Pypi package


Interface python pour thesorimed


* License : GNU General Public License v3
* Documentation: https://pythonthesorimed.readthedocs.org/en/latest/
* Source: https://github.com/jgirardet/pythonthesorimed


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
==============

.. code-block:: shell

pipenv install pythonthesorimed
ou
pip install pythonthesorimed

Usage
======

Initialisation
----------------

.. code-block:: python

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

Utilisation des API thesorimed
--------------------------------

.. code-block:: python

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 :

.. code-block:: python

>>> 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.

.. code-block:: python

session.fuzzy('chaine')



Parseur
==========

Cloner le dépot puis :

.. code-block:: shell

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``



Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
pythonthesorimed-0.3.0-py3-none-any.whl (12.1 kB) Copy SHA256 hash SHA256 Wheel py3
pythonthesorimed-0.3.0.tar.gz (24.3 kB) Copy SHA256 hash SHA256 Source None

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page