SciELO Publishing Schema XML document front matter metadata reader/sanitizer
Project description
Clea
This project is an XML front matter metadata reader for documents that almost follows the SciELO Publishing Schema, extracting and sanitizing the values regarding the affiliations.
Installation
Installation with minimal requirements, intended for use within Python, as an imported package:
pip install scielo-clea
Installation for use as a server (mainly for testing):
pip install scielo-clea[server]
Running the testing server
You can run the development server using the flask CLI. For example, for listening at 8080 from every host:
FLASK_APP=clea.server flask run -h 0.0.0.0 -p 8080
In a production server with 4 worker processes for handling requests, you can, for example:
- Install gunicorn (it's not a dependency)
- Run
gunicorn -b 0.0.0.0:8080 -w 4 clea.server:app
Clea as a library
A simple example to see all the extracted data is:
from clea.core import Article
from pprint import pprint
art = Article("some_file.xml")
pprint(art.data_full)
That's a dictionary of lists with all the "raw" extracted data.
The keys of that dictionary can be directly accessed,
so one can avoid extracting everything from the XML
by getting just the specific items/attributes
(e.g. art["journal_meta"][0].data_full
or art.journal_meta[0].data_full
instead of art.data_full["journal_meta"][0]
).
These items/attributes are always lists, for example:
art["aff"]
: List ofclea.core.Branch
instancesart["sub_article"]
: List ofclea.core.SubArticle
instancesart["contrib"][0]["contrib_name"]
: List of strings
Where the art["contrib"][0]
is a Branch
instance,
and all such instances behave in the same way
(there's no nested branches).
That can be seen as another way to navigate in the former dictionary,
the last example should return the same list one would get with
art.data_full["contrib"][0]["contrib_name"]
,
but without extracting everything else
that appears in the art.data_full
dictionary.
More simple stuff that can be done:
len(art.aff) # Number of <aff> entries
len(art.sub_article) # Number of <sub-article>
art.contrib[0].data_full # Data from the first contributor as a dict
# Something like {"type": ["translation"], "lang": ["en"]},
# the content from <sub-article> attributes
art["sub_article"][0]["article"][0].data_full
# A string with the article title, accessing just the desired content
art["article_meta"][0]["article_title"][0]
All SubArticle
, Article
and Branch
instances
have the data_full
property and the get
method,
the latter being internally used for item/attribute getting.
Their behavior is:
Branch.get
always returns a list of stringsArticle.get("sub_article")
returns a list ofSubArticle
Article.get(...)
returns a list ofBranch
SubArticle
behaves likeArticle
The extracted information is not exhaustive! Its result should not be seen as a replacement of the raw XML.
One of the goals of this library was
to help on creating a tabular data from a given XML
with as many rows as required
to have a pair of a matching <aff>
and <contrib>
in each row.
These are the functions that does that matching:
clea.join.aff_contrib_inner_gen(article)
clea.join.aff_contrib_full_gen(article)
clea.join.aff_contrib_inner(article)
clea.join.aff_contrib_full(article)
The ones with the _gen
suffix are generator functions
that yields a tuple with two Branch
entries (or None
),
the other ones return a list of merged dictionaries
in an almost tabular format (dictionary of lists of strings).
Each list regarding these elements for these specific elements
should usually have at most one string,
but that's not always the case even for these specific elements,
then one should be careful when using the data
property.
The inner
and full
in the names
regards to INNER JOIN
and FULL OUTER JOIN
from SQL,
meaning the unmatched elements
(all <aff>
and <contrib>
unreferred nodes)
are discarded in the former strategy,
whereas they're forcefully matched with None
in the latter.
To print all the extracted data from a XML
including both the INNER JOIN
and FULL OUTER JOIN
of matching <aff>
and <contrib>
pairs,
similar to the test server response:
from clea.join import aff_contrib_inner, aff_contrib_full
pprint({**article.data_full,
"aff_contrib_full": aff_contrib_full(article),
"aff_contrib_inner": aff_contrib_inner(article),
})
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file scielo-clea-0.3.0.tar.gz
.
File metadata
- Download URL: scielo-clea-0.3.0.tar.gz
- Upload date:
- Size: 11.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 99da38d1c019e432718c018f7038b695fd33e000be1e4c07cafc705e07bd0bd2 |
|
MD5 | 56e2bd1757cf673f8e3982701770e7a2 |
|
BLAKE2b-256 | 31b73e191172c6c2bda676785906155a6f4ed6288b90dcd77e087dc014b2bfab |