Skip to main content

Industrial-strength Natural Language Processing (NLP) with Python and Cython

Project description

# spaCy: Industrial-strength NLP

spaCy is a library for advanced Natural Language Processing in Python and
Cython. It's built on the very latest research, and was designed from day one
to be used in real products. spaCy comes with
[pre-trained statistical models](https://spacy.io/models) and word vectors, and
currently supports tokenization for **30+ languages**. It features the
**fastest syntactic parser** in the world, convolutional
**neural network models** for tagging, parsing and **named entity recognition**
and easy **deep learning** integration. It's commercial open-source software,
released under the MIT license.

💫 **Version 2.1 out now!** [Check out the release notes here.](https://github.com/explosion/spaCy/releases)

[![Travis Build Status](https://img.shields.io/travis/explosion/spaCy/master.svg?style=flat-square&logo=travis)](https://travis-ci.org/explosion/spaCy)
[![Appveyor Build Status](https://img.shields.io/appveyor/ci/explosion/spaCy/master.svg?style=flat-square&logo=appveyor)](https://ci.appveyor.com/project/explosion/spaCy)
[![Current Release Version](https://img.shields.io/github/release/explosion/spacy.svg?style=flat-square)](https://github.com/explosion/spaCy/releases)
[![pypi Version](https://img.shields.io/pypi/v/spacy.svg?style=flat-square)](https://pypi.python.org/pypi/spacy)
[![conda Version](https://img.shields.io/conda/vn/conda-forge/spacy.svg?style=flat-square)](https://anaconda.org/conda-forge/spacy)
[![Python wheels](https://img.shields.io/badge/wheels-%E2%9C%93-4c1.svg?longCache=true&style=flat-square&logo=python&logoColor=white)](https://github.com/explosion/wheelwright/releases)
[![spaCy on Twitter](https://img.shields.io/twitter/follow/spacy_io.svg?style=social&label=Follow)](https://twitter.com/spacy_io)

## 📖 Documentation

| Documentation | |
| --- | --- |
| [spaCy 101] | New to spaCy? Here's everything you need to know!
| [Usage Guides] | How to use spaCy and its features. |
| [New in v2.0] | New features, backwards incompatibilities and migration guide. |
| [API Reference] | The detailed reference for spaCy's API. |
| [Models] | Download statistical language models for spaCy. |
| [Universe] | Libraries, extensions, demos, books and courses. |
| [Changelog] | Changes and version history. |
| [Contribute] | How to contribute to the spaCy project and code base. |

[spaCy 101]: https://spacy.io/usage/spacy-101
[New in v2.0]: https://spacy.io/usage/v2#migrating
[Usage Guides]: https://spacy.io/usage/
[API Reference]: https://spacy.io/api/
[Models]: https://spacy.io/models
[Universe]: https://spacy.io/universe
[Changelog]: https://spacy.io/usage/#changelog
[Contribute]: https://github.com/explosion/spaCy/blob/master/CONTRIBUTING.md

## 💬 Where to ask questions

The spaCy project is maintained by [@honnibal](https://github.com/honnibal)
and [@ines](https://github.com/ines). Please understand that we won't be able
to provide individual support via email. We also believe that help is much more
valuable if it's shared publicly, so that more people can benefit from it.

* **Bug Reports**: [GitHub Issue Tracker]
* **Usage Questions**: [Stack Overflow] · [Gitter Chat] · [Reddit User Group]
* **General Discussion**: [Gitter Chat] · [Reddit User Group]

[GitHub Issue Tracker]: https://github.com/explosion/spaCy/issues
[Stack Overflow]: http://stackoverflow.com/questions/tagged/spacy
[Gitter Chat]: https://gitter.im/explosion/spaCy
[Reddit User Group]: https://www.reddit.com/r/spacynlp

## Features

* **Fastest syntactic parser** in the world
* **Named entity** recognition
* Non-destructive **tokenization**
* Support for **30+ languages**
* Pre-trained [statistical models](https://spacy.io/models) and word vectors
* Easy **deep learning** integration
* Part-of-speech tagging
* Labelled dependency parsing
* Syntax-driven sentence segmentation
* Built in **visualizers** for syntax and NER
* Convenient string-to-hash mapping
* Export to numpy data arrays
* Efficient binary serialization
* Easy **model packaging** and deployment
* State-of-the-art speed
* Robust, rigorously evaluated accuracy

📖 **For more details, see the
[facts, figures and benchmarks](https://spacy.io/usage/facts-figures).**

## Install spaCy

For detailed installation instructions, see the
[documentation](https://spacy.io/usage).

* **Operating system**: macOS / OS X · Linux · Windows (Cygwin, MinGW, Visual Studio)
* **Python version**: Python 2.7, 3.4+ (only 64 bit)
* **Package managers**: [pip] · [conda] (via `conda-forge`)

[pip]: https://pypi.python.org/pypi/spacy
[conda]: https://anaconda.org/conda-forge/spacy

### pip

Using pip, spaCy releases are available as source packages and binary wheels
(as of `v2.0.13`).

```bash
pip install spacy
```

When using pip it is generally recommended to install packages in a virtual
environment to avoid modifying system state:

```bash
python -m venv .env
source .env/bin/activate
pip install spacy
```

### conda

Thanks to our great community, we've finally re-added conda support. You can now
install spaCy via `conda-forge`:

```bash
conda config --add channels conda-forge
conda install spacy
```

For the feedstock including the build recipe and configuration,
check out [this repository](https://github.com/conda-forge/spacy-feedstock).
Improvements and pull requests to the recipe and setup are always appreciated.

### Updating spaCy

Some updates to spaCy may require downloading new statistical models. If you're
running spaCy v2.0 or higher, you can use the `validate` command to check if
your installed models are compatible and if not, print details on how to update
them:

```bash
pip install -U spacy
python -m spacy validate
```

If you've trained your own models, keep in mind that your training and runtime
inputs must match. After updating spaCy, we recommend **retraining your models**
with the new version.

📖 **For details on upgrading from spaCy 1.x to spaCy 2.x, see the
[migration guide](https://spacy.io/usage/v2#migrating).**

## Download models

As of v1.7.0, models for spaCy can be installed as **Python packages**.
This means that they're a component of your application, just like any
other module. Models can be installed using spaCy's `download` command,
or manually by pointing pip to a path or URL.

| Documentation | |
| --- | --- |
| [Available Models] | Detailed model descriptions, accuracy figures and benchmarks. |
| [Models Documentation] | Detailed usage instructions. |

[Available Models]: https://spacy.io/models
[Models Documentation]: https://spacy.io/docs/usage/models

```bash
# out-of-the-box: download best-matching default model
python -m spacy download en

# download best-matching version of specific model for your spaCy installation
python -m spacy download en_core_web_lg

# pip install .tar.gz archive from path or URL
pip install /Users/you/en_core_web_sm-2.0.0.tar.gz
```

### Loading and using models

To load a model, use `spacy.load()` with the model's shortcut link:

```python
import spacy
nlp = spacy.load('en')
doc = nlp(u'This is a sentence.')
```

If you've installed a model via pip, you can also `import` it directly and
then call its `load()` method:

```python
import spacy
import en_core_web_sm

nlp = en_core_web_sm.load()
doc = nlp(u'This is a sentence.')
```

📖 **For more info and examples, check out the
[models documentation](https://spacy.io/docs/usage/models).**

### Support for older versions

If you're using an older version (`v1.6.0` or below), you can still download
and install the old models from within spaCy using `python -m spacy.en.download all`
or `python -m spacy.de.download all`. The `.tar.gz` archives are also
[attached to the v1.6.0 release](https://github.com/explosion/spaCy/tree/v1.6.0).
To download and install the models manually, unpack the archive, drop the
contained directory into `spacy/data` and load the model via `spacy.load('en')`
or `spacy.load('de')`.

## Compile from source

The other way to install spaCy is to clone its
[GitHub repository](https://github.com/explosion/spaCy) and build it from
source. That is the common way if you want to make changes to the code base.
You'll need to make sure that you have a development environment consisting of a
Python distribution including header files, a compiler,
[pip](https://pip.pypa.io/en/latest/installing/),
[virtualenv](https://virtualenv.pypa.io/) and [git](https://git-scm.com)
installed. The compiler part is the trickiest. How to do that depends on your
system. See notes on Ubuntu, OS X and Windows for details.

```bash
# make sure you are using the latest pip
python -m pip install -U pip
git clone https://github.com/explosion/spaCy
cd spaCy

python -m venv .env
source .env/bin/activate
export PYTHONPATH=`pwd`
pip install -r requirements.txt
python setup.py build_ext --inplace
```

Compared to regular install via pip, [requirements.txt](requirements.txt)
additionally installs developer dependencies such as Cython. For more details
and instructions, see the documentation on
[compiling spaCy from source](https://spacy.io/usage/#source) and the
[quickstart widget](https://spacy.io/usage/#section-quickstart) to get
the right commands for your platform and Python version.

### Ubuntu

Install system-level dependencies via `apt-get`:

```bash
sudo apt-get install build-essential python-dev git
```

### macOS / OS X

Install a recent version of [XCode](https://developer.apple.com/xcode/),
including the so-called "Command Line Tools". macOS and OS X ship with Python
and git preinstalled.

### Windows

Install a version of the [Visual C++ Build Tools](https://visualstudio.microsoft.com/visual-cpp-build-tools/) or
[Visual Studio Express](https://www.visualstudio.com/vs/visual-studio-express/)
that matches the version that was used to compile your Python
interpreter. For official distributions these are VS 2008 (Python 2.7),
VS 2010 (Python 3.4) and VS 2015 (Python 3.5).

## Run tests

spaCy comes with an [extensive test suite](spacy/tests). In order to run the
tests, you'll usually want to clone the repository and build spaCy from source.
This will also install the required development dependencies and test utilities
defined in the `requirements.txt`.

Alternatively, you can find out where spaCy is installed and run `pytest` on
that directory. Don't forget to also install the test utilities via spaCy's
`requirements.txt`:

```bash
python -c "import os; import spacy; print(os.path.dirname(spacy.__file__))"
pip install -r path/to/requirements.txt
python -m pytest <spacy-directory>
```

See [the documentation](https://spacy.io/usage/#tests) for more details and
examples.

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

spacy-nightly-2.1.0a3.tar.gz (22.4 MB view details)

Uploaded Source

Built Distributions

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

spacy_nightly-2.1.0a3-cp37-cp37m-manylinux1_x86_64.whl (22.5 MB view details)

Uploaded CPython 3.7m

spacy_nightly-2.1.0a3-cp37-cp37m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl (25.0 MB view details)

Uploaded CPython 3.7mmacOS 10.10+ Intel (x86-64, i386)macOS 10.10+ x86-64macOS 10.6+ Intel (x86-64, i386)macOS 10.9+ Intel (x86-64, i386)macOS 10.9+ x86-64

spacy_nightly-2.1.0a3-cp36-cp36m-manylinux1_x86_64.whl (22.5 MB view details)

Uploaded CPython 3.6m

spacy_nightly-2.1.0a3-cp36-cp36m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl (25.2 MB view details)

Uploaded CPython 3.6mmacOS 10.10+ Intel (x86-64, i386)macOS 10.10+ x86-64macOS 10.6+ Intel (x86-64, i386)macOS 10.9+ Intel (x86-64, i386)macOS 10.9+ x86-64

spacy_nightly-2.1.0a3-cp35-cp35m-manylinux1_x86_64.whl (22.5 MB view details)

Uploaded CPython 3.5m

spacy_nightly-2.1.0a3-cp27-cp27mu-manylinux1_x86_64.whl (22.5 MB view details)

Uploaded CPython 2.7mu

spacy_nightly-2.1.0a3-cp27-cp27m-manylinux1_x86_64.whl (22.5 MB view details)

Uploaded CPython 2.7m

spacy_nightly-2.1.0a3-cp27-cp27m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl (25.1 MB view details)

Uploaded CPython 2.7mmacOS 10.10+ Intel (x86-64, i386)macOS 10.10+ x86-64macOS 10.6+ Intel (x86-64, i386)macOS 10.9+ Intel (x86-64, i386)macOS 10.9+ x86-64

File details

Details for the file spacy-nightly-2.1.0a3.tar.gz.

File metadata

  • Download URL: spacy-nightly-2.1.0a3.tar.gz
  • Upload date:
  • Size: 22.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy-nightly-2.1.0a3.tar.gz
Algorithm Hash digest
SHA256 30bfec908e3068266bda684edb90ae4046d4cd0857a669be8e8d724a4169d4e7
MD5 150ef48e4eae642ac6e64f971c6da6a9
BLAKE2b-256 f7bbfda860f73d3a1c6b5b0fcf8a10946d3e1ee05c7bd24cb49a60d51e8af6c9

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

  • Download URL: spacy_nightly-2.1.0a3-cp37-cp37m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 22.5 MB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy_nightly-2.1.0a3-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 06661bf0f521f4a755e6b65fad7515905ec82d4905b67c901da32ca8abc1c686
MD5 429a21b7b7855ca23c45917b1a9340ad
BLAKE2b-256 39d01e9be82baef570ed23b716b63235ab3bb11f8c01c4540369bbb537dbf14d

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp37-cp37m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl.

File metadata

File hashes

Hashes for spacy_nightly-2.1.0a3-cp37-cp37m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl
Algorithm Hash digest
SHA256 b3f84015761a7338b878bf6b3cd31373b3e7872d9339dd7ae572fbde9b7e7200
MD5 371b672ed1184e63b8b3f381168f060e
BLAKE2b-256 296cc14fead8d1f3c0c547f37ea955a60756ce989d32317072544b8b4f035b36

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

  • Download URL: spacy_nightly-2.1.0a3-cp36-cp36m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 22.5 MB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy_nightly-2.1.0a3-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 57434dbaa9bd61372dcfbc56d43612dd6895067ca31f3bf6b5750aca5524d781
MD5 3ce9a525206c11db504c7e245ff7c5b0
BLAKE2b-256 9dab10978dc4eafa75d417a538bd51c1bb869e2a2c9ace8a8a88da12e92a8628

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp36-cp36m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl.

File metadata

File hashes

Hashes for spacy_nightly-2.1.0a3-cp36-cp36m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl
Algorithm Hash digest
SHA256 a018f0443b5a7054be3747e5099a06b0448d45f1d37c3b7e527437ec8b1e01ad
MD5 28f4c39c05edfa7a60ea5c8c97445cb3
BLAKE2b-256 8376572fb8bf52b21878ce9ae43116a12e67de4f5c98fe2ec768b2e8034fd96d

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp35-cp35m-manylinux1_x86_64.whl.

File metadata

  • Download URL: spacy_nightly-2.1.0a3-cp35-cp35m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 22.5 MB
  • Tags: CPython 3.5m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy_nightly-2.1.0a3-cp35-cp35m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 d921567f45e748fd5d19cee9668afcca1cb9366f00210ee0d7ab6d332220a17e
MD5 37125170e2e024694d8e3a2abf0b9d59
BLAKE2b-256 5155db357ef5c96b29b128015dabace61c0fd2c2b9c5e210551e79d4f7e7a010

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp27-cp27mu-manylinux1_x86_64.whl.

File metadata

  • Download URL: spacy_nightly-2.1.0a3-cp27-cp27mu-manylinux1_x86_64.whl
  • Upload date:
  • Size: 22.5 MB
  • Tags: CPython 2.7mu
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy_nightly-2.1.0a3-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 58ed5bc8717269b16607e360e980fb4e33deb5df84fc223330e032b977a1b850
MD5 5fb06c9bd8611cd3c13704d44f11c6e2
BLAKE2b-256 5a130e1f71eb4f35da7f323ebb9269d3243f4cf6cc70c3b4899f33c8dab83c2d

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp27-cp27m-manylinux1_x86_64.whl.

File metadata

  • Download URL: spacy_nightly-2.1.0a3-cp27-cp27m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 22.5 MB
  • Tags: CPython 2.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.1 setuptools/39.0.1 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for spacy_nightly-2.1.0a3-cp27-cp27m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 4ddda411a317358720ec22819c6da43b2cfb32e31ac9c9bed715d6ab8932e63c
MD5 5a9dcf1d9438c93535c5bf61d1f9348e
BLAKE2b-256 151e956792fda40b39657d3db77732222fda4679c9413fa2b1d0e34697d67b65

See more details on using hashes here.

File details

Details for the file spacy_nightly-2.1.0a3-cp27-cp27m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl.

File metadata

File hashes

Hashes for spacy_nightly-2.1.0a3-cp27-cp27m-macosx_10_6_intel.macosx_10_9_intel.macosx_10_9_x86_64.macosx_10_10_intel.macosx_10_10_x86_64.whl
Algorithm Hash digest
SHA256 eb78a563f26a7f52fff6a6f7587897162af51da6576fa4a4453f3c52bcad9dfe
MD5 6995918c529facbd706bb2a16f246d74
BLAKE2b-256 e08ce9f0c6700f643c4ce7847b6233a3da9647229854ebb068d2e5a39d1b244b

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