API per ricavare le pubblicazioni dall'archivio istituzionale dell' Università degli studi di Udine.
Per utilizzare l'API si consiglia innanzitutto di creare un nuovo ambiente virtuale.
Tramite conda: https://docs.conda.io/projects/conda/en/latest/user-guide/getting-started.html#managing-environments
Tramite venv: https://docs.python.org/3/tutorial/venv.html
Una volta creato l'ambiente virtuale sarà possibile installare il package contenente l'API:
pip install uniudpubapi
Dopo aver installato il package si può iniziare ad utilizzare il codice per l'importazione delle pubblicazioni.
Di seguito si mostra come si può utilizzare l'API per esportare le pubblicazioni dei membri di un dipartimento in formato markdown e in formato bibtex.
Innanzitutto bisogna importare le classi che servono per importare e scrivere le pubblicazioni:
from uniudpubapi.dep_pubs import DepartmentPublications
from uniudpubapi.writers import BibtexPublicationWriter, MarkdownPublicationWriter
Poi sarà necessario definire i membri del dipartimento (o il gruppo di ricercatori) tramite un dizionario che ne specifica il nome e il codice:
# Sostiturire nome e codice con quelli dei membri di cui si vuole ottenere le pubblicazioni
department = {
"nome cognome": "rp1234"
}
Quindi definire le informazioni che si vuole ricavare, sia per quando riguarda gli elementi che andranno a essere visualizzati all'interno di un file markdown che per gli elementi che andranno inseritit all'interno del bibtex della pubblicazione.
bibtex_elements = ["authors", "title", "year", "journal", "handle",
"publication type", "publisher", "volume", "book_title",
"doi", "pages", "series"]
markdown_elements = ["title", "authors", "year", "doi", "publication type",
"abstract"]
Gli elementi disponibili si possono trovare alla fine del file uniudpubepi/elements.py di questo repository, in cui si vedrà una successione di comandi di questo tipo:
factory.register_type_of_element("title", Title)
factory.register_type_of_element("handle", Handle)
factory.register_type_of_element("publication type", PubType)
factory.register_type_of_element("authors", Authors)
factory.register_type_of_element("year", Year)
# ....
# ....
Gli elementi che si vedono all'interno del file sono tutti quelli che si possono importare (In nuove versioni tale lista può essere aggiornata con nuovi elementi).
Quindi si può procedere alla creazione di un oggetto di tipo DepartmentPublications, al cui costruttore si passa il dizionario con i membri del dipartimento e le liste delgi elementi (bibtex e markdown). N.B. gli argomenti devono essere nell'ordine mostrato nell'esempio.
d = DepartmentPublications(department, bibtex_elements, markdown_elements)
Quando si vuole popolare l'oggetto con tutte le informazioni basta eseguire il seguente comando:
d.find_department_publications() # Dove d è l'oggetto creato in precedenza
Si noti che l'esecuzione di questa funzione richiederà una certa quantità di tempo, in quanto devono essere scaricate tutte le pubblicazioni. Tutte le pubblicazioni saranno salvate in una variabile d'istanza dell'oggetto. SE ALCUNI ELEMENTI (ES.DOI, ABSTRACT ...) PER LA SINGOLA PUBBLICAZIONE NON DOVESSERO ESSERE TROVATI, VENGONO SEMPLICEMENTE IGNORATI, SENZA AVVISI
Infine, se si desidera esportare le pubblicazioni, si possono utilizzare i seguenti comandi. Per l'esportazione in markdown:
md = MarkdownPublicationWriter(d)
md.export()
Per l'esportazione in bibtex:
bib = BibtexPublicationWriter(d)
bib.export()
Il parametro passato ad entrambi i costruttori è un oggetto di tipo "DepartmentPublication" in cui è già stata chiamata la funzione "find_department_publications()" (Vedi paragrafo precedente). <\br>
Il metodo "export" accetta un argomento opzionale che indica il percordo in cui salvare tutte le pubblicazioni. Il valore di default è "./pubs". Se la directory indicata non esiste, verrà creata in automatico. <\br>
Il metodo export crea una directory per ogni pubblicazione, nominata con il titolo della pubblicazione. All'interno della directory della singola pubblicazione viene inserito un file "index.md" per l'esportazione in markdown e un file "cite.bib" per l'esportazione in bibtex.
Questo formato è stato scelto in modo che sia compatibile con il formato richiesto dal tema "academic" per il generatore di siti statici Hugo (vedi https://wowchemy.com/docs/content/publications/ per maggiori informazioni).
├── pubs/
│ ├── pub1-title/
│ │ ├── cite.bib
│ │ ├── index.md
│ ├── pub2-title/
│ │ ├── cite.bib
│ │ ├── index.md
│ └── pub3-title/
│ │ ├── cite.bib
│ │ ├── index.md
├── ....