Metadata-Version: 2.1
Name: excelcy
Version: 0.2.4
Summary: Excel Integration with SpaCy. Includes, Entity training, Entity matcher pipe.
Home-page: https://github.com/kororo/excelcy
Author: Robertus Johansyah
Author-email: me@kororo.co
Maintainer: Robertus Johansyah
Maintainer-email: me@kororo.co
License: MIT
Keywords: spacy,spacy-pipeline,spacy-nlp,nlp,python,python3,entity,training,excel,xlsx,spacy-extensions
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Requires-Dist: spacy (<3.0,>=2.0.11)
Requires-Dist: pyexcel (<1.0,>=0.5.0)
Requires-Dist: pyexcel-xlsx (<1.0,>=0.5.6)
Requires-Dist: pyyaml (<4.0,>=3.12)

ExcelCy
=======

.. image:: https://badge.fury.io/py/excelcy.svg
    :target: https://badge.fury.io/py/excelcy

.. image:: https://travis-ci.com/kororo/excelcy.svg?branch=master
    :target: https://travis-ci.com/kororo/excelcy

.. image:: https://coveralls.io/repos/github/kororo/excelcy/badge.svg?branch=master
    :target: https://coveralls.io/github/kororo/excelcy?branch=master

.. image:: https://badges.gitter.im/excelcy.png
    :target: https://gitter.im/excelcy
    :alt: Gitter

------

ExcelCy is a toolkit to integrate Excel to spaCy NLP training experiences. Training NER using XLSX from PDF, DOCX, PPT, PNG or JPG. ExcelCy has pipeline to match Entity with PhraseMatcher or Matcher in regular expression.

ExcelCy is Powerful
-------------------

`Simple Style Training <https://spacy.io/usage/training#training-simple-style>`__, from spaCy documentation, demonstrates how to train NER using spaCy:

.. code-block:: python

    TRAIN_DATA = [
         ("Uber blew through $1 million a week", {'entities': [(0, 4, 'ORG')]}),
         ("Google rebrands its business apps", {'entities': [(0, 6, "ORG")]})]

    nlp = spacy.blank('en')
    optimizer = nlp.begin_training()
    for i in range(20):
        random.shuffle(TRAIN_DATA)
        for text, annotations in TRAIN_DATA:
            nlp.update([text], [annotations], sgd=optimizer)
    nlp.to_disk('/model')

The **TRAIN_DATA**, describes sentences and annotated entities to be trained. It is cumbersome to always count the characters. With ExcelCy, (start,end) characters can be omitted.

.. code-block:: python

    from excelcy import ExcelCy
    # collect sentences, annotate Entities and train NER using spaCy
    excelcy = ExcelCy.execute(file_path='https://github.com/kororo/excelcy/raw/master/tests/data/test_data_01.xlsx')
    # use the nlp object as per spaCy API
    doc = excelcy.nlp('Google rebrands its business apps')
    # or save it for faster bootstrap for application
    excelcy.nlp.to_disk('/model')

ExcelCy is Friendly
-------------------

ExcelCy training is divided into phases, the example Excel file can be found in `tests/data/test_data_01.xlsx <https://github.com/kororo/excelcy/raw/master/tests/data/test_data_01.xlsx>`__ :

1. Discovery
^^^^^^^^^^^^

The first phase is to collect sentences from data source in sheet "source". The data source can be either:

- Text: Direct sentence values.
- Files: PDF, DOCX, PPT, PNG or JPG will be parsed using `textract <https://github.com/deanmalmgren/textract>`__.

2. Preparation
^^^^^^^^^^^^^^

Next phase, the sentences will be analysed in sheet "prepare", based on:

- Current Data Model: Using spaCy API of **nlp(sentence).ents**
- Phrase pattern: Robertus Johansyah, Uber, Google, Amazon
- Regex pattern: ^([0-1]?[0-9]|2[0-3]):[0-5][0-9]$

3. Training
^^^^^^^^^^^

Main phase of NER training, which described in `Simple Style Training <https://spacy.io/usage/training#training-simple-style>`__. The data is iterated from sheet "train", check sheet "config" to control the parameters.

4. Consolidation
^^^^^^^^^^^^^^^^

The last phase, is to test/save the results and repeat the phases if required.

ExcelCy is Comprehensive
------------------------

Under the hood, ExcelCy has strong and well-defined data storage. At any given phase above, the data can be inspected.

.. code-block:: python

    from excelcy import ExcelCy

    excelcy = ExcelCy()
    # load configuration from XLSX or YML or JSON
    # excelcy.load(file_path='test_data_01.xlsx')
    # or define manually
    excelcy.storage.config = Config(nlp_base='en_core_web_sm', train_iteration=2, train_drop=0.2)
    print(json.dumps(excelcy.storage.items(), indent=2))

    # add sources
    excelcy.storage.source.add(kind='text', value='Robertus Johansyah is the maintainer ExcelCy')
    excelcy.storage.source.add(kind='textract', value='tests/data/source/test_source_01.txt')
    excelcy.discover()
    print(json.dumps(excelcy.storage.items(), indent=2))

    # add phrase matcher Robertus Johansyah -> PERSON
    excelcy.storage.prepare.add(kind='phrase', value='Robertus Johansyah', entity='PERSON')
    excelcy.prepare()
    print(json.dumps(excelcy.storage.items(), indent=2))

    # train it
    excelcy.train()
    print(json.dumps(excelcy.storage.items(), indent=2))

    # test it
    doc = excelcy.nlp('Robertus Johansyah is maintainer ExcelCy')
    print(json.dumps(excelcy.storage.items(), indent=2))


Features
--------

- Load multiple data sources such as Word documents, PowerPoint presentations, PDF or images.
- Import/Export configuration with JSON, YML or Excel.
- Add custom Entity labels.
- Rule based phrase matching using `PhraseMatcher <https://spacy.io/usage/linguistic-features#adding-phrase-patterns>`__
- Rule based matching using `regex + Matcher <https://spacy.io/usage/linguistic-features#regex>`__
- Train Named Entity Recogniser with ease

Install
-------

Either use the famous pip or clone this repository and execute the setup.py file.

.. code-block:: bash

    $ pip install excelcy
    # ensure you have the language model installed before
    $ spacy download en

Train
-----

To train the spaCy model:

.. code-block:: python

    from excelcy import ExcelCy
    excelcy = ExcelCy.execute(file_path='test_data_01.xlsx')

Note: `tests/data/test_data_01.xlsx <https://github.com/kororo/excelcy/raw/master/tests/data/test_data_01.xlsx>`__

Data Definition
---------------

ExcelCy has data definition which expressed in `api.yml <https://github.com/kororo/excelcy/raw/master/data/api.yml>`__. As long as, data given in this specific format and structure, ExcelCy will able to support any type of data format. Check out, the Excel file format in `api.xlsx <https://github.com/kororo/excelcy/raw/master/data/api.xlsx>`__. Data classes are defined with `attrs <https://github.com/python-attrs/attrs>`__, check in `storage.py <https://github.com/kororo/excelcy/raw/master/excelcy/storage.py>`__ for more detail.

TODO
----

- [X] Start get cracking into spaCy

- [ ] More features and enhancements listed `here <https://github.com/kororo/excelcy/labels/enhancement>`__

    - [ ] [`link <https://github.com/kororo/excelcy/issues/3>`__] Add CLI support
    - [ ] [`link <https://github.com/kororo/excelcy/issues/4>`__] Add export outputs such as identified Entities, Tags
    - [ ] Add special case for tokenisation described `here <https://spacy.io/usage/linguistic-features#special-cases>`__
    - [ ] Add custom tags.
    - [ ] Add classifier text training described `here <https://spacy.io/usage/training#textcat>`__
    - [ ] Add exception subtext when there is multiple occurrence in text. (Google Pay is awesome Google product)
    - [ ] Add tag annotation in sheet: train
    - [ ] Add ref in data storage
    - [ ] Improve speed and performance
    - [X] Add list of patterns easily (such as kitten breed.
    - [X] Add more data structure check in Excel and more warning messages
    - [X] Add plugin, otherwise just extends for now.
    - [X] [`link <https://github.com/kororo/excelcy/issues/2>`__] Improve experience
    - [X] [`link <https://github.com/kororo/excelcy/issues/1>`__] Add more file format such as YML, JSON. Make standardise and well documented on data structure.
    - [X] Add support to accept sentences to Excel

- [X] Submit to Prodigy Universe

FAQ
---

**What is that idx columns in the Excel sheet?**

The idea is to give reference between two things. Imagine in sheet "train", like to know where the sentence generated from in sheet "source".

**Can ExcelCy import/export to X, Y, Z data format?**

ExcelCy has strong and well-defined data storage, thanks to `attrs <https://github.com/python-attrs/attrs>`__. It is possible to import/export data in any format.

**ExcelCy accepts suggestions/ideas?**

Yes! Please submit them into new issue with label "enhancement".

Acknowledgement
---------------

This project uses other awesome projects:

- `attrs <https://github.com/python-attrs/attrs>`__: Python Classes Without Boilerplate.
- `pyexcel <https://github.com/pyexcel/pyexcel>`__: Single API for reading, manipulating and writing data in csv, ods, xls, xlsx and xlsm files.
- `pyyaml <https://github.com/yaml/pyyaml>`__: The next generation YAML parser and emitter for Python.
- `spacy <https://github.com/explosion/spaCy>`__: Industrial-strength Natural Language Processing (NLP) with Python and Cython.
- `textract <https://github.com/deanmalmgren/textract>`__: extract text from any document. no muss. no fuss.


