.. | |||
v1 | 4 months ago | ||
README.md | 4 months ago | ||
examples.http | 4 months ago | ||
requirements.txt | 1 year ago | ||
swagger.json | 1 month ago | ||
tests.hurl | 4 months ago |
Cette instance propose des outils pour traiter les auteurs.
L'application à utiliser est lodex-workers-python
.
Il faut préciser dans le fichier de configuration de l'instance qu'elle utilise les paquets node:
@ezs/spawn
@ezs/analytics
@ezs/basics
@ezs/storage
{ "packages": [ "@ezs/spawn@1.2.31", "@ezs/analytics@2.0.22", "@ezs/basics@2.1.0", "@ezs/storage@2.0.2" ] }
Ce web service prend en entrée du JSON avec deux champs, id
et value
, et renvoie un JSON avec un identifiant ORCID dans le champ value
.
Le champ value
doit contenir un json contenant au minimum les deux champs suivants:
firstName
: Le prénom de la personne que l'on souhaite trouverlastName
: Le nom de la personne que l'on souhaite trouverDe plus, d'autres champs facultatifs (mais fortement recommandés d'utiliser pour plus de précision) sont disponibles :
email
: Une liste []
d'emails de la personne que l'on souhaite trouvertitles
: Une liste []
de titres de publication scientifique de la personne que l'on souhaite trouvercoAuthors
: Une liste []
de co-auteurs de la personne que l'on souhaite trouveraffiliations
: Une liste []
d'affiliations (présentes ou passées) de la personne que l'on souhaite trouverLe programme fonctionne de la façon suivante :
firstName
et lastName
donnés récupérant un nombre nameDepth
de personnes, nameDepth
étant un paramètre fixé à 20, et pouvant être modifié via l'url.worksDepth
maximum de publications de la personne, worksDepth
étant un paramètre fixé à 20, et pouvant être modifié via l'url. De ces publications il va extraire les titres ainsi que tous les co-auteurs disponibles.
Pour les combinaisons de prénom/nom très communes dans certains pays (par exemple John Smith, Yue Chen), il est conseillé d'augmenter le paramètre nameDepth
. Cependant cela risque également d'augmenter le temps de calcul.
De plus l'algorithme renverra dans la majorité des cas un résultat, mais il est possible que celui-ci soit incorrect si aucun des arguments d'entrée n'a aidé à identifier la personne recherchée.
Remarque : On ne pourra pas trouver une personne à l'aide de titres, co-auteurs, emails et affiliations si cette personne n'a pas rentré ces données dans son compte orcid, par conséquent une personne étant sur orcid mais n'ayant mis aucune information à disposition peut ne pas être trouvée.
$ cat <<EOF | curl -X POST --data-binary @- "https://authors-tools.services.inist.fr/v1/orcid-disambiguation/orcidDisambiguation" [{"id":"1","value":[{"firstName" : "Pascal", "lastName" : "Cuxac", "email" : ["blabla@blabla.fr","pascal.cuxac@inist.fr"]}]}, {"id":"2","value":[{"firstName" : "Rubén", "lastName" : "Vázquez-Cárdenas", "coAuthors" : ["Juan pablo Martínez-Pastor"]}]}] EOF
Sortie
[{"id":"1","value":"0000-0002-6809-5654"}, {"id":"2","value":"0000-0002-8416-869X"}] EOF
Exemple d'url en modifiant les paramètres nameDepth
et worksDepth
:
Ce web-service renvoie le genre d'un prénom.
Il prend en entrée du JSON avec deux champs, id
et value
, et renvoie un JSON avec le genre du prénom dans le champ value
.
Le fichier nam_dict_merged.txt
est la fusion de deux fichiers venant de sources différentes :
nam_dict.txt
vient de données de la librairie gender_guesser
. Ces données sont sous licence GNU.national_names.csv
vient de la base de données Kaggle
et contient tous les prénoms français données depuis 1900. Ce fichier a été pré-traité pour correspondre à la structure du nam_dict.txt
. On le retrouve ainsi dans le fichier nam_dict_merged.txt
à partir de la ligne 48822.Le fichier preprocessing.py
permet de créer le name_gender.pickle
qui contient des couples {"prénom":"genre"}. Enfin le fichier gender.py
permet de renvoyer le genre d'un prénom en gérant les différentes types de prénoms. Il renvoie le genre si le prénom est trouvé, un "unknown" si le prénom n'est pas dans la base et une "erreur" si le prénom n'a pas le format attendu par le web-service.
Entrée
$ cat <<EOF | curl -X POST --data-binary @- "https://authors-tools.services.inist.fr/v1/first-name/gender" [{"id": "1", "value": "Jean Christophe"},{"id": "2", "value": "Amke"},{"id": "3", "value": "Seong-Eun"},{"id": "4", "value": "James A."}] EOF
Sortie
[ {"id": "1", "value": "male"}, {"id": "2", "value": "mostly_female"}, {"id": "3", "value": "female"}, {"id": "4", "value": "male"} ]
Ce web-service renvoie pour chaque affiliations d'auteurs si l'organisme d'appartenance est privé ou public. Il prend en entrée du JSON avec deux champs, id
et value
, et renvoie un JSON avec le nom de l'entreprise et son statut dans le champ value
.
Le programme filtre dans un premier temps les affiliations avec une liste de mots-clés issus du privé et du public. Ensuite, les affiliations restantes sont traitées (normalisation et découpage des abréviations). Les noms des entreprises et leur numéro de département (quand il est présent) sont envoyés par requête à l'API Recherche d’entreprises. Celle-ci renvoie toute une liste d'informations parmi lesquelles le champ est_service_public
. Si ce champ est à False, alors il s'agit d'une entreprise privée.
NB : Ce WS peut être un peu lent car l'API limite le nombre de requêtes à 7 par seconde.
Entrée
$ cat <<EOF | curl -X POST --data-binary @- "https://authors-tools.services.inist.fr/v1/corporate/private-public" [{"id": "1", "value": "Abeeway, F-06903 Sophia Antipolis, France"},{"id": "2", "value": "AiryLab SARL, 34 Rue Jean Baptiste Malon, F-04800 Greoux Les Bains, France"},{"id": "3", "value": "4G TECHNOL, F-06370 Mouans Sartoux, France"},{"id": "4", "value": "Univ Cote dAzur, INRIA, Ansys, Nice, France"}] EOF
Sortie
[ { "id": 1, "value": { "organisme": "abeeway", "statut": "private" } }, { "id": 2, "value": { "organisme": "airylab sarl", "statut": "private" } }, { "id": 3, "value": { "organisme": "n/a", "statut": "n/a" } }, { "id": 4, "value": { "organisme": "univ cote dazur", "statut": "public" } } ]