Skip to main content

ELFEN - Efficient Linguistic Feature Extraction for Natural Language Datasets

Project description

ELFEN - Efficient Linguistic Feature Extraction for Natural Language Datasets

This Python package provides efficient linguistic feature extraction for text datasets (i.e. datasets with N text instances, in a tabular structure).

For further information, check the GitHub repository and the documentation

Using spacy models

If you want to use the spacy backbone, you will need to download the respective model, e.g. "en_core_web_sm":

python -m spacy download en_core_web_sm

Usage of third-party resources usable in this package

For the full functionality, some external resources are necessary. While most of them are downloaded and located automatically, some have to be loaded manually.

WordNet features

To use wordnet features, download open multilingual wordnet using:

python -m wn download omw:1.4

Note that for some languages, you will need to install another wordnet collection. For example, for German, you can use the following command:

python -m wn download odenet:1.4

For more information on the available wordnet collections, consult the wn package documentation.

Note that if you have used elfen or the wn package before, you may encounter errors from the wn package about an incompatible database schema. In that case, you can use the following command to reset the database:

  import wn
  wn.reset_database(rebuild=True)

Emotion lexicons

The emotion lexicons used in this package have to be downloaded manually due to licensing restrictions. After downloading, the extracted folders have to be placed in the respective directories.

To do so, download the intensity lexicons from the NRC Emotion Intensity Lexicon page, the association lexicons from the NRC Emotion Association Lexicon page and the vad lexicons from the NRC VAD Lexicon page. Note that for the VAD lexicon, you will have to use the version 1. The newer version 2.1 is not integrated in elfen yet.

To use them in elfen, find the elfen_resources directory in your local elfen installation (for example with pip):

python -m pip show elfen

Then, the elfen_resources directory should be located in the same directory as the elfen package directory.

Create the following subdirectories if they do not exist yet:

  • elfen_resources/Emotion/Sentiment
  • elfen_resources/Emotion/VAD
  • elfen_resources/Emotion/Intensity

Then, place the downloaded extracted zip folders in the respective directories:

  • Place the extracted zip folder of the NRC Emotion Intensity Lexicon in elfen_resources/Emotion/Intensity/
  • Place the extracted zip folder of the NRC Emotion Association Lexicon in elfen_resources/Emotion/Sentiment/
  • Place the extracted zip folder of the NRC VAD Lexicon in elfen_resources/Emotion/VAD/

Licences of lexicons

The extraction of psycholinguistic, emotion/lexicon and semantic features relies on third-party resources such as lexicons. Please refer to the original author's licenses and conditions for usage, and cite them if you use the resources through this package in your analyses.

For an overview which features use which resource, and how to export all third-party resource references in a bibtex string, consult the documentation.

Multiprocessing and limiting the numbers of cores used

The underlying dataframe library, polars, uses all available cores by default. If you are working on a shared server, you may want to consider limiting the resources available to polars. To do that, you will have to set the POLARS_MAX_THREADS variable in your shell, e.g.:

export POLARS_MAX_THREADS=8

Acknowledgements

While all feature extraction functions in this package are written from scratch, the choice of features in the readability and lexical richness feature areas (partially) follows the readability and lexicalrichness Python packages.

We use the wn Python package to extract Open Multilingual Wordnet synsets.

Citation

If you use this package in your work, for now, please cite

@misc{maurer-2025-elfen,
  author = {Maurer, Maximilian},
  title = {ELFEN - Efficient Linguistic Feature Extraction for Natural Language Datasets},
  year = {2025},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/mmmaurer/elfen}},
}

Project details


Download files

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

Source Distribution

elfen-1.3.1.tar.gz (61.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

elfen-1.3.1-py3-none-any.whl (65.2 kB view details)

Uploaded Python 3

File details

Details for the file elfen-1.3.1.tar.gz.

File metadata

  • Download URL: elfen-1.3.1.tar.gz
  • Upload date:
  • Size: 61.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for elfen-1.3.1.tar.gz
Algorithm Hash digest
SHA256 6786dc33a2d1a8178d2ed4187f2bba9022d70e171e007c6212087404eb82fcc9
MD5 2e85023796964cfe3e8846fec32e585b
BLAKE2b-256 8e16b99a02adc4451e994fe1b88537c6e1c32c3ba041427343371617d5031aa4

See more details on using hashes here.

File details

Details for the file elfen-1.3.1-py3-none-any.whl.

File metadata

  • Download URL: elfen-1.3.1-py3-none-any.whl
  • Upload date:
  • Size: 65.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for elfen-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4eadb0e6a9ac4b11014e95927b28dd3e561fc0fb66403ca0b36842b89cab5467
MD5 66968183d2ee61c88bb18afa08322757
BLAKE2b-256 46bda62c63699a7f64a2c5c3921b3c4f354ca845e433e9343ab8f203bb890f86

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page