mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-12 10:16:27 +03:00
Update develop from master
This commit is contained in:
commit
4336397ecb
|
@ -8,7 +8,6 @@ environment:
|
||||||
- PYTHON: "C:\\Python27-x64"
|
- PYTHON: "C:\\Python27-x64"
|
||||||
#- PYTHON: "C:\\Python34"
|
#- PYTHON: "C:\\Python34"
|
||||||
#- PYTHON: "C:\\Python35"
|
#- PYTHON: "C:\\Python35"
|
||||||
#- PYTHON: "C:\\Python27-x64"
|
|
||||||
#- DISTUTILS_USE_SDK: "1"
|
#- DISTUTILS_USE_SDK: "1"
|
||||||
#- PYTHON: "C:\\Python34-x64"
|
#- PYTHON: "C:\\Python34-x64"
|
||||||
#- DISTUTILS_USE_SDK: "1"
|
#- DISTUTILS_USE_SDK: "1"
|
||||||
|
|
106
.github/contributors/DimaBryuhanov.md
vendored
Normal file
106
.github/contributors/DimaBryuhanov.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [X] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | -------------------- |
|
||||||
|
| Name | Dmitry Briukhanov |
|
||||||
|
| Company name (if applicable) | - |
|
||||||
|
| Title or role (if applicable) | - |
|
||||||
|
| Date | 7/24/2018 |
|
||||||
|
| GitHub username | DimaBryuhanov |
|
||||||
|
| Website (optional) | |
|
106
.github/contributors/EmilStenstrom.md
vendored
Normal file
106
.github/contributors/EmilStenstrom.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [x] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | ----------------------- |
|
||||||
|
| Name | Emil Stenström |
|
||||||
|
| Company name (if applicable) | - |
|
||||||
|
| Title or role (if applicable) | - |
|
||||||
|
| Date | 2018-07-28 |
|
||||||
|
| GitHub username | EmilStenstrom |
|
||||||
|
| Website (optional) | https://friendlybit.com |
|
106
.github/contributors/aashishg.md
vendored
Normal file
106
.github/contributors/aashishg.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [x] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | -------------------- |
|
||||||
|
| Name | Aashish Gangwani |
|
||||||
|
| Company name (if applicable) | |
|
||||||
|
| Title or role (if applicable) | |
|
||||||
|
| Date | 7/08/2018 |
|
||||||
|
| GitHub username | aashishg |
|
||||||
|
| Website (optional) | |
|
106
.github/contributors/sammous.md
vendored
Normal file
106
.github/contributors/sammous.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | -------------------- |
|
||||||
|
| Name | Sami Moustachir |
|
||||||
|
| Company name (if applicable) | |
|
||||||
|
| Title or role (if applicable) | Data Scientist |
|
||||||
|
| Date | 2018-08-02 |
|
||||||
|
| GitHub username | sammous |
|
||||||
|
| Website (optional) | https://samimoustachir.com |
|
106
.github/contributors/vikaskyadav.md
vendored
Normal file
106
.github/contributors/vikaskyadav.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | -------------------- |
|
||||||
|
| Name | vikas yadav |
|
||||||
|
| Company name (if applicable) | |
|
||||||
|
| Title or role (if applicable) | Data Scientist |
|
||||||
|
| Date | 1 August 2018 |
|
||||||
|
| GitHub username | vikaskyadav |
|
||||||
|
| Website (optional) | www.vikaskyadav.tk |
|
106
.github/contributors/wojtuch.md
vendored
Normal file
106
.github/contributors/wojtuch.md
vendored
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
# spaCy contributor agreement
|
||||||
|
|
||||||
|
This spaCy Contributor Agreement (**"SCA"**) is based on the
|
||||||
|
[Oracle Contributor Agreement](http://www.oracle.com/technetwork/oca-405177.pdf).
|
||||||
|
The SCA applies to any contribution that you make to any product or project
|
||||||
|
managed by us (the **"project"**), and sets out the intellectual property rights
|
||||||
|
you grant to us in the contributed materials. The term **"us"** shall mean
|
||||||
|
[ExplosionAI UG (haftungsbeschränkt)](https://explosion.ai/legal). The term
|
||||||
|
**"you"** shall mean the person or entity identified below.
|
||||||
|
|
||||||
|
If you agree to be bound by these terms, fill in the information requested
|
||||||
|
below and include the filled-in version with your first pull request, under the
|
||||||
|
folder [`.github/contributors/`](/.github/contributors/). The name of the file
|
||||||
|
should be your GitHub username, with the extension `.md`. For example, the user
|
||||||
|
example_user would create the file `.github/contributors/example_user.md`.
|
||||||
|
|
||||||
|
Read this agreement carefully before signing. These terms and conditions
|
||||||
|
constitute a binding legal agreement.
|
||||||
|
|
||||||
|
## Contributor Agreement
|
||||||
|
|
||||||
|
1. The term "contribution" or "contributed materials" means any source code,
|
||||||
|
object code, patch, tool, sample, graphic, specification, manual,
|
||||||
|
documentation, or any other material posted or submitted by you to the project.
|
||||||
|
|
||||||
|
2. With respect to any worldwide copyrights, or copyright applications and
|
||||||
|
registrations, in your contribution:
|
||||||
|
|
||||||
|
* you hereby assign to us joint ownership, and to the extent that such
|
||||||
|
assignment is or becomes invalid, ineffective or unenforceable, you hereby
|
||||||
|
grant to us a perpetual, irrevocable, non-exclusive, worldwide, no-charge,
|
||||||
|
royalty-free, unrestricted license to exercise all rights under those
|
||||||
|
copyrights. This includes, at our option, the right to sublicense these same
|
||||||
|
rights to third parties through multiple levels of sublicensees or other
|
||||||
|
licensing arrangements;
|
||||||
|
|
||||||
|
* you agree that each of us can do all things in relation to your
|
||||||
|
contribution as if each of us were the sole owners, and if one of us makes
|
||||||
|
a derivative work of your contribution, the one who makes the derivative
|
||||||
|
work (or has it made will be the sole owner of that derivative work;
|
||||||
|
|
||||||
|
* you agree that you will not assert any moral rights in your contribution
|
||||||
|
against us, our licensees or transferees;
|
||||||
|
|
||||||
|
* you agree that we may register a copyright in your contribution and
|
||||||
|
exercise all ownership rights associated with it; and
|
||||||
|
|
||||||
|
* you agree that neither of us has any duty to consult with, obtain the
|
||||||
|
consent of, pay or render an accounting to the other for any use or
|
||||||
|
distribution of your contribution.
|
||||||
|
|
||||||
|
3. With respect to any patents you own, or that you can license without payment
|
||||||
|
to any third party, you hereby grant to us a perpetual, irrevocable,
|
||||||
|
non-exclusive, worldwide, no-charge, royalty-free license to:
|
||||||
|
|
||||||
|
* make, have made, use, sell, offer to sell, import, and otherwise transfer
|
||||||
|
your contribution in whole or in part, alone or in combination with or
|
||||||
|
included in any product, work or materials arising out of the project to
|
||||||
|
which your contribution was submitted, and
|
||||||
|
|
||||||
|
* at our option, to sublicense these same rights to third parties through
|
||||||
|
multiple levels of sublicensees or other licensing arrangements.
|
||||||
|
|
||||||
|
4. Except as set out above, you keep all right, title, and interest in your
|
||||||
|
contribution. The rights that you grant to us under these terms are effective
|
||||||
|
on the date you first submitted a contribution to us, even if your submission
|
||||||
|
took place before the date you sign these terms.
|
||||||
|
|
||||||
|
5. You covenant, represent, warrant and agree that:
|
||||||
|
|
||||||
|
* Each contribution that you submit is and shall be an original work of
|
||||||
|
authorship and you can legally grant the rights set out in this SCA;
|
||||||
|
|
||||||
|
* to the best of your knowledge, each contribution will not violate any
|
||||||
|
third party's copyrights, trademarks, patents, or other intellectual
|
||||||
|
property rights; and
|
||||||
|
|
||||||
|
* each contribution shall be in compliance with U.S. export control laws and
|
||||||
|
other applicable export and import laws. You agree to notify us if you
|
||||||
|
become aware of any circumstance which would make any of the foregoing
|
||||||
|
representations inaccurate in any respect. We may publicly disclose your
|
||||||
|
participation in the project, including the fact that you have signed the SCA.
|
||||||
|
|
||||||
|
6. This SCA is governed by the laws of the State of California and applicable
|
||||||
|
U.S. Federal law. Any choice of law rules will not apply.
|
||||||
|
|
||||||
|
7. Please place an “x” on one of the applicable statement below. Please do NOT
|
||||||
|
mark both statements:
|
||||||
|
|
||||||
|
* [x] I am signing on behalf of myself as an individual and no other person
|
||||||
|
or entity, including my employer, has or will have rights with respect to my
|
||||||
|
contributions.
|
||||||
|
|
||||||
|
* [ ] I am signing on behalf of my employer or a legal entity and I have the
|
||||||
|
actual authority to contractually bind that entity.
|
||||||
|
|
||||||
|
## Contributor Details
|
||||||
|
|
||||||
|
| Field | Entry |
|
||||||
|
|------------------------------- | -------------------- |
|
||||||
|
| Name | Wojciech Lukasiewicz |
|
||||||
|
| Company name (if applicable) | |
|
||||||
|
| Title or role (if applicable) | |
|
||||||
|
| Date | 13.08.2018 |
|
||||||
|
| GitHub username | wojtuch |
|
||||||
|
| Website (optional) | |
|
15
bin/push-tag.sh
Executable file
15
bin/push-tag.sh
Executable file
|
@ -0,0 +1,15 @@
|
||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# Insist repository is clean
|
||||||
|
git diff-index --quiet HEAD
|
||||||
|
|
||||||
|
git checkout master
|
||||||
|
git pull origin master
|
||||||
|
version=$(grep "__version__ = " spacy/about.py)
|
||||||
|
version=${version/__version__ = }
|
||||||
|
version=${version/\'/}
|
||||||
|
version=${version/\'/}
|
||||||
|
git tag "v$version"
|
||||||
|
git push origin --tags
|
48
examples/pipeline/custom_sentence_segmentation.py
Normal file
48
examples/pipeline/custom_sentence_segmentation.py
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
'''Example of adding a pipeline component to prohibit sentence boundaries
|
||||||
|
before certain tokens.
|
||||||
|
|
||||||
|
What we do is write to the token.is_sent_start attribute, which
|
||||||
|
takes values in {True, False, None}. The default value None allows the parser
|
||||||
|
to predict sentence segments. The value False prohibits the parser from inserting
|
||||||
|
a sentence boundary before that token. Note that fixing the sentence segmentation
|
||||||
|
should also improve the parse quality.
|
||||||
|
|
||||||
|
The specific example here is drawn from https://github.com/explosion/spaCy/issues/2627
|
||||||
|
Other versions of the model may not make the original mistake, so the specific
|
||||||
|
example might not be apt for future versions.
|
||||||
|
'''
|
||||||
|
import plac
|
||||||
|
import spacy
|
||||||
|
|
||||||
|
def prevent_sentence_boundaries(doc):
|
||||||
|
for token in doc:
|
||||||
|
if not can_be_sentence_start(token):
|
||||||
|
token.is_sent_start = False
|
||||||
|
return doc
|
||||||
|
|
||||||
|
def can_be_sentence_start(token):
|
||||||
|
if token.i == 0:
|
||||||
|
return True
|
||||||
|
elif token.is_title:
|
||||||
|
return True
|
||||||
|
elif token.nbor(-1).is_punct:
|
||||||
|
return True
|
||||||
|
elif token.nbor(-1).is_space:
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
|
def main():
|
||||||
|
nlp = spacy.load('en_core_web_lg')
|
||||||
|
raw_text = "Been here and I'm loving it."
|
||||||
|
doc = nlp(raw_text)
|
||||||
|
sentences = [sent.string.strip() for sent in doc.sents]
|
||||||
|
print(sentences)
|
||||||
|
nlp.add_pipe(prevent_sentence_boundaries, before='parser')
|
||||||
|
doc = nlp(raw_text)
|
||||||
|
sentences = [sent.string.strip() for sent in doc.sents]
|
||||||
|
print(sentences)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
plac.call(main)
|
|
@ -1,5 +1,5 @@
|
||||||
cython>=0.24,<0.28.0
|
cython>=0.24,<0.28.0
|
||||||
numpy>=1.7
|
numpy>=1.15.0
|
||||||
cymem>=1.30,<1.32
|
cymem>=1.30,<1.32
|
||||||
preshed>=1.0.0,<2.0.0
|
preshed>=1.0.0,<2.0.0
|
||||||
thinc>=6.11.2,<6.12.0
|
thinc>=6.11.2,<6.12.0
|
||||||
|
|
2
setup.py
2
setup.py
|
@ -188,7 +188,7 @@ def setup_package():
|
||||||
ext_modules=ext_modules,
|
ext_modules=ext_modules,
|
||||||
scripts=['bin/spacy'],
|
scripts=['bin/spacy'],
|
||||||
install_requires=[
|
install_requires=[
|
||||||
'numpy>=1.7',
|
'numpy>=1.15.0',
|
||||||
'murmurhash>=0.28,<0.29',
|
'murmurhash>=0.28,<0.29',
|
||||||
'cymem>=1.30,<1.32',
|
'cymem>=1.30,<1.32',
|
||||||
'preshed>=1.0.0,<2.0.0',
|
'preshed>=1.0.0,<2.0.0',
|
||||||
|
|
|
@ -1,5 +1,8 @@
|
||||||
# coding: utf8
|
# coding: utf8
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
import warnings
|
||||||
|
warnings.filterwarnings("ignore", message="numpy.dtype size changed")
|
||||||
|
warnings.filterwarnings("ignore", message="numpy.ufunc size changed")
|
||||||
|
|
||||||
from .cli.info import info as cli_info
|
from .cli.info import info as cli_info
|
||||||
from .glossary import explain
|
from .glossary import explain
|
||||||
|
|
|
@ -3,13 +3,13 @@
|
||||||
# https://github.com/pypa/warehouse/blob/master/warehouse/__about__.py
|
# https://github.com/pypa/warehouse/blob/master/warehouse/__about__.py
|
||||||
|
|
||||||
__title__ = 'spacy-nightly'
|
__title__ = 'spacy-nightly'
|
||||||
__version__ = '2.1.0a0'
|
__version__ = '2.1.0a2'
|
||||||
__summary__ = 'Industrial-strength Natural Language Processing (NLP) with Python and Cython'
|
__summary__ = 'Industrial-strength Natural Language Processing (NLP) with Python and Cython'
|
||||||
__uri__ = 'https://spacy.io'
|
__uri__ = 'https://spacy.io'
|
||||||
__author__ = 'Explosion AI'
|
__author__ = 'Explosion AI'
|
||||||
__email__ = 'contact@explosion.ai'
|
__email__ = 'contact@explosion.ai'
|
||||||
__license__ = 'MIT'
|
__license__ = 'MIT'
|
||||||
__release__ = True
|
__release__ = False
|
||||||
|
|
||||||
__download_url__ = 'https://github.com/explosion/spacy-models/releases/download'
|
__download_url__ = 'https://github.com/explosion/spacy-models/releases/download'
|
||||||
__compatibility__ = 'https://raw.githubusercontent.com/explosion/spacy-models/master/compatibility.json'
|
__compatibility__ = 'https://raw.githubusercontent.com/explosion/spacy-models/master/compatibility.json'
|
||||||
|
|
|
@ -4,9 +4,12 @@ from __future__ import unicode_literals
|
||||||
from .._messages import Messages
|
from .._messages import Messages
|
||||||
from ...compat import json_dumps, path2str
|
from ...compat import json_dumps, path2str
|
||||||
from ...util import prints
|
from ...util import prints
|
||||||
|
from ...gold import iob_to_biluo
|
||||||
|
import re
|
||||||
|
|
||||||
|
|
||||||
def conllu2json(input_path, output_path, n_sents=10, use_morphology=False):
|
def conllu2json(input_path, output_path, n_sents=10, use_morphology=False):
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Convert conllu files into JSON format for use with train cli.
|
Convert conllu files into JSON format for use with train cli.
|
||||||
use_morphology parameter enables appending morphology to tags, which is
|
use_morphology parameter enables appending morphology to tags, which is
|
||||||
|
@ -14,15 +17,27 @@ def conllu2json(input_path, output_path, n_sents=10, use_morphology=False):
|
||||||
"""
|
"""
|
||||||
# by @dvsrepo, via #11 explosion/spacy-dev-resources
|
# by @dvsrepo, via #11 explosion/spacy-dev-resources
|
||||||
|
|
||||||
|
"""
|
||||||
|
Extract NER tags if available and convert them so that they follow
|
||||||
|
BILUO and the Wikipedia scheme
|
||||||
|
"""
|
||||||
|
# by @katarkor
|
||||||
|
|
||||||
docs = []
|
docs = []
|
||||||
sentences = []
|
sentences = []
|
||||||
conll_tuples = read_conllx(input_path, use_morphology=use_morphology)
|
conll_tuples = read_conllx(input_path, use_morphology=use_morphology)
|
||||||
|
checked_for_ner = False
|
||||||
|
has_ner_tags = False
|
||||||
|
|
||||||
for i, (raw_text, tokens) in enumerate(conll_tuples):
|
for i, (raw_text, tokens) in enumerate(conll_tuples):
|
||||||
sentence, brackets = tokens[0]
|
sentence, brackets = tokens[0]
|
||||||
sentences.append(generate_sentence(sentence))
|
if not checked_for_ner:
|
||||||
|
has_ner_tags = is_ner(sentence[5][0])
|
||||||
|
checked_for_ner = True
|
||||||
|
sentences.append(generate_sentence(sentence, has_ner_tags))
|
||||||
# Real-sized documents could be extracted using the comments on the
|
# Real-sized documents could be extracted using the comments on the
|
||||||
# conluu document
|
# conluu document
|
||||||
|
|
||||||
if(len(sentences) % n_sents == 0):
|
if(len(sentences) % n_sents == 0):
|
||||||
doc = create_doc(sentences, i)
|
doc = create_doc(sentences, i)
|
||||||
docs.append(doc)
|
docs.append(doc)
|
||||||
|
@ -37,6 +52,21 @@ def conllu2json(input_path, output_path, n_sents=10, use_morphology=False):
|
||||||
title=Messages.M032.format(name=path2str(output_file)))
|
title=Messages.M032.format(name=path2str(output_file)))
|
||||||
|
|
||||||
|
|
||||||
|
def is_ner(tag):
|
||||||
|
|
||||||
|
"""
|
||||||
|
Check the 10th column of the first token to determine if the file contains
|
||||||
|
NER tags
|
||||||
|
"""
|
||||||
|
|
||||||
|
tag_match = re.match('([A-Z_]+)-([A-Z_]+)', tag)
|
||||||
|
if tag_match:
|
||||||
|
return True
|
||||||
|
elif tag == "O":
|
||||||
|
return True
|
||||||
|
else:
|
||||||
|
return False
|
||||||
|
|
||||||
def read_conllx(input_path, use_morphology=False, n=0):
|
def read_conllx(input_path, use_morphology=False, n=0):
|
||||||
text = input_path.open('r', encoding='utf-8').read()
|
text = input_path.open('r', encoding='utf-8').read()
|
||||||
i = 0
|
i = 0
|
||||||
|
@ -49,7 +79,7 @@ def read_conllx(input_path, use_morphology=False, n=0):
|
||||||
for line in lines:
|
for line in lines:
|
||||||
|
|
||||||
parts = line.split('\t')
|
parts = line.split('\t')
|
||||||
id_, word, lemma, pos, tag, morph, head, dep, _1, _2 = parts
|
id_, word, lemma, pos, tag, morph, head, dep, _1, iob = parts
|
||||||
if '-' in id_ or '.' in id_:
|
if '-' in id_ or '.' in id_:
|
||||||
continue
|
continue
|
||||||
try:
|
try:
|
||||||
|
@ -58,7 +88,7 @@ def read_conllx(input_path, use_morphology=False, n=0):
|
||||||
dep = 'ROOT' if dep == 'root' else dep
|
dep = 'ROOT' if dep == 'root' else dep
|
||||||
tag = pos if tag == '_' else tag
|
tag = pos if tag == '_' else tag
|
||||||
tag = tag+'__'+morph if use_morphology else tag
|
tag = tag+'__'+morph if use_morphology else tag
|
||||||
tokens.append((id_, word, tag, head, dep, 'O'))
|
tokens.append((id_, word, tag, head, dep, iob))
|
||||||
except:
|
except:
|
||||||
print(line)
|
print(line)
|
||||||
raise
|
raise
|
||||||
|
@ -68,17 +98,47 @@ def read_conllx(input_path, use_morphology=False, n=0):
|
||||||
if n >= 1 and i >= n:
|
if n >= 1 and i >= n:
|
||||||
break
|
break
|
||||||
|
|
||||||
|
def simplify_tags(iob):
|
||||||
|
|
||||||
def generate_sentence(sent):
|
"""
|
||||||
(id_, word, tag, head, dep, _) = sent
|
Simplify tags obtained from the dataset in order to follow Wikipedia
|
||||||
|
scheme (PER, LOC, ORG, MISC). 'PER', 'LOC' and 'ORG' keep their tags, while
|
||||||
|
'GPE_LOC' is simplified to 'LOC', 'GPE_ORG' to 'ORG' and all remaining tags to
|
||||||
|
'MISC'.
|
||||||
|
"""
|
||||||
|
|
||||||
|
new_iob = []
|
||||||
|
for tag in iob:
|
||||||
|
tag_match = re.match('([A-Z_]+)-([A-Z_]+)', tag)
|
||||||
|
if tag_match:
|
||||||
|
prefix = tag_match.group(1)
|
||||||
|
suffix = tag_match.group(2)
|
||||||
|
if suffix == 'GPE_LOC':
|
||||||
|
suffix = 'LOC'
|
||||||
|
elif suffix == 'GPE_ORG':
|
||||||
|
suffix = 'ORG'
|
||||||
|
elif suffix != 'PER' and suffix != 'LOC' and suffix != 'ORG':
|
||||||
|
suffix = 'MISC'
|
||||||
|
tag = prefix + '-' + suffix
|
||||||
|
new_iob.append(tag)
|
||||||
|
return new_iob
|
||||||
|
|
||||||
|
def generate_sentence(sent, has_ner_tags):
|
||||||
|
(id_, word, tag, head, dep, iob) = sent
|
||||||
sentence = {}
|
sentence = {}
|
||||||
tokens = []
|
tokens = []
|
||||||
|
if has_ner_tags:
|
||||||
|
iob = simplify_tags(iob)
|
||||||
|
biluo = iob_to_biluo(iob)
|
||||||
for i, id in enumerate(id_):
|
for i, id in enumerate(id_):
|
||||||
token = {}
|
token = {}
|
||||||
|
token["id"] = id
|
||||||
token["orth"] = word[i]
|
token["orth"] = word[i]
|
||||||
token["tag"] = tag[i]
|
token["tag"] = tag[i]
|
||||||
token["head"] = head[i] - id
|
token["head"] = head[i] - id
|
||||||
token["dep"] = dep[i]
|
token["dep"] = dep[i]
|
||||||
|
if has_ner_tags:
|
||||||
|
token["ner"] = biluo[i]
|
||||||
tokens.append(token)
|
tokens.append(token)
|
||||||
sentence["tokens"] = tokens
|
sentence["tokens"] = tokens
|
||||||
return sentence
|
return sentence
|
||||||
|
|
|
@ -38,12 +38,13 @@ from ..compat import json_dumps
|
||||||
gold_preproc=("Use gold preprocessing", "flag", "G", bool),
|
gold_preproc=("Use gold preprocessing", "flag", "G", bool),
|
||||||
version=("Model version", "option", "V", str),
|
version=("Model version", "option", "V", str),
|
||||||
meta_path=("Optional path to meta.json. All relevant properties will be "
|
meta_path=("Optional path to meta.json. All relevant properties will be "
|
||||||
"overwritten.", "option", "m", Path))
|
"overwritten.", "option", "m", Path),
|
||||||
|
verbose=("Display more information for debug", "option", None, bool))
|
||||||
def train(lang, output_dir, train_data, dev_data, n_iter=30, n_sents=0,
|
def train(lang, output_dir, train_data, dev_data, n_iter=30, n_sents=0,
|
||||||
parser_multitasks='', entity_multitasks='',
|
parser_multitasks='', entity_multitasks='',
|
||||||
use_gpu=-1, vectors=None, no_tagger=False,
|
use_gpu=-1, vectors=None, no_tagger=False,
|
||||||
no_parser=False, no_entities=False, gold_preproc=False,
|
no_parser=False, no_entities=False, gold_preproc=False,
|
||||||
version="0.0.0", meta_path=None):
|
version="0.0.0", meta_path=None, verbose=False):
|
||||||
"""
|
"""
|
||||||
Train a model. Expects data in spaCy's JSON format.
|
Train a model. Expects data in spaCy's JSON format.
|
||||||
"""
|
"""
|
||||||
|
@ -146,7 +147,7 @@ def train(lang, output_dir, train_data, dev_data, n_iter=30, n_sents=0,
|
||||||
gold_preproc=gold_preproc))
|
gold_preproc=gold_preproc))
|
||||||
nwords = sum(len(doc_gold[0]) for doc_gold in dev_docs)
|
nwords = sum(len(doc_gold[0]) for doc_gold in dev_docs)
|
||||||
start_time = timer()
|
start_time = timer()
|
||||||
scorer = nlp_loaded.evaluate(dev_docs)
|
scorer = nlp_loaded.evaluate(dev_docs, verbose)
|
||||||
end_time = timer()
|
end_time = timer()
|
||||||
if use_gpu < 0:
|
if use_gpu < 0:
|
||||||
gpu_wps = None
|
gpu_wps = None
|
||||||
|
|
|
@ -39,7 +39,7 @@ def tags_to_entities(tags):
|
||||||
continue
|
continue
|
||||||
elif tag.startswith('I'):
|
elif tag.startswith('I'):
|
||||||
if start is None:
|
if start is None:
|
||||||
raise ValueError(Errors.E067.format(tags=tags[:i]))
|
raise ValueError(Errors.E067.format(tags=tags[:i+1]))
|
||||||
continue
|
continue
|
||||||
if tag.startswith('U'):
|
if tag.startswith('U'):
|
||||||
entities.append((tag[2:], i, i))
|
entities.append((tag[2:], i, i))
|
||||||
|
|
|
@ -7,6 +7,8 @@ from .tag_map_general import TAG_MAP
|
||||||
from .stop_words import STOP_WORDS
|
from .stop_words import STOP_WORDS
|
||||||
from .lex_attrs import LEX_ATTRS
|
from .lex_attrs import LEX_ATTRS
|
||||||
from .lemmatizer import LEMMA_RULES, LEMMA_INDEX, LEMMA_EXC
|
from .lemmatizer import LEMMA_RULES, LEMMA_INDEX, LEMMA_EXC
|
||||||
|
from .lemmatizer.lemmatizer import GreekLemmatizer
|
||||||
|
from .syntax_iterators import SYNTAX_ITERATORS
|
||||||
from .punctuation import TOKENIZER_PREFIXES, TOKENIZER_SUFFIXES, TOKENIZER_INFIXES
|
from .punctuation import TOKENIZER_PREFIXES, TOKENIZER_SUFFIXES, TOKENIZER_INFIXES
|
||||||
from ..tokenizer_exceptions import BASE_EXCEPTIONS
|
from ..tokenizer_exceptions import BASE_EXCEPTIONS
|
||||||
from .norm_exceptions import NORM_EXCEPTIONS
|
from .norm_exceptions import NORM_EXCEPTIONS
|
||||||
|
@ -20,15 +22,23 @@ class GreekDefaults(Language.Defaults):
|
||||||
lex_attr_getters = dict(Language.Defaults.lex_attr_getters)
|
lex_attr_getters = dict(Language.Defaults.lex_attr_getters)
|
||||||
lex_attr_getters.update(LEX_ATTRS)
|
lex_attr_getters.update(LEX_ATTRS)
|
||||||
lex_attr_getters[LANG] = lambda text: 'el' # ISO code
|
lex_attr_getters[LANG] = lambda text: 'el' # ISO code
|
||||||
lex_attr_getters[NORM] = add_lookups(Language.Defaults.lex_attr_getters[NORM], BASE_NORMS, NORM_EXCEPTIONS)
|
lex_attr_getters[NORM] = add_lookups(
|
||||||
|
Language.Defaults.lex_attr_getters[NORM], BASE_NORMS, NORM_EXCEPTIONS)
|
||||||
tokenizer_exceptions = update_exc(BASE_EXCEPTIONS, TOKENIZER_EXCEPTIONS)
|
tokenizer_exceptions = update_exc(BASE_EXCEPTIONS, TOKENIZER_EXCEPTIONS)
|
||||||
stop_words = STOP_WORDS
|
stop_words = STOP_WORDS
|
||||||
lemma_rules = LEMMA_RULES
|
|
||||||
lemma_index = LEMMA_INDEX
|
|
||||||
tag_map = TAG_MAP
|
tag_map = TAG_MAP
|
||||||
prefixes = TOKENIZER_PREFIXES
|
prefixes = TOKENIZER_PREFIXES
|
||||||
suffixes = TOKENIZER_SUFFIXES
|
suffixes = TOKENIZER_SUFFIXES
|
||||||
infixes = TOKENIZER_INFIXES
|
infixes = TOKENIZER_INFIXES
|
||||||
|
syntax_iterators = SYNTAX_ITERATORS
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def create_lemmatizer(cls, nlp=None):
|
||||||
|
lemma_rules = LEMMA_RULES
|
||||||
|
lemma_index = LEMMA_INDEX
|
||||||
|
lemma_exc = LEMMA_EXC
|
||||||
|
return GreekLemmatizer(index=lemma_index, exceptions=lemma_exc,
|
||||||
|
rules=lemma_rules)
|
||||||
|
|
||||||
|
|
||||||
class Greek(Language):
|
class Greek(Language):
|
||||||
|
@ -39,4 +49,3 @@ class Greek(Language):
|
||||||
|
|
||||||
# set default export – this allows the language class to be lazy-loaded
|
# set default export – this allows the language class to be lazy-loaded
|
||||||
__all__ = ['Greek']
|
__all__ = ['Greek']
|
||||||
|
|
||||||
|
|
|
@ -9,11 +9,20 @@ Example sentences to test spaCy and its language models.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
sentences = [
|
sentences = [
|
||||||
"Η άνιση κατανομή του πλούτου και του εισοδήματος, η οποία έχει λάβει τρομερές διαστάσεις, δεν δείχνει τάσεις βελτίωσης.",
|
'''Η άνιση κατανομή του πλούτου και του εισοδήματος, η οποία έχει λάβει
|
||||||
"Ο στόχος της σύντομης αυτής έκθεσης είναι να συνοψίσει τα κυριότερα συμπεράσματα των επισκοπήσεων κάθε μιας χώρας.",
|
τρομερές διαστάσεις, δεν δείχνει τάσεις βελτίωσης.''',
|
||||||
"Μέχρι αργά χθες το βράδυ ο πλοιοκτήτης παρέμενε έξω από το γραφείο του γενικού γραμματέα του υπουργείου, ενώ είχε μόνον τηλεφωνική επικοινωνία με τον υπουργό.",
|
'''Ο στόχος της σύντομης αυτής έκθεσης είναι να συνοψίσει τα κυριότερα
|
||||||
"Σύμφωνα με καλά ενημερωμένη πηγή, από την επεξεργασία του προέκυψε ότι οι δράστες της επίθεσης ήταν δύο, καθώς και ότι προσέγγισαν και αποχώρησαν από το σημείο με μοτοσικλέτα.",
|
συμπεράσματα των επισκοπήσεων κάθε μιας χώρας.''',
|
||||||
|
'''Μέχρι αργά χθες το βράδυ ο πλοιοκτήτης παρέμενε έξω από το γραφείο του
|
||||||
|
γενικού γραμματέα του υπουργείου, ενώ είχε μόνον τηλεφωνική επικοινωνία με
|
||||||
|
τον υπουργό.''',
|
||||||
|
'''Σύμφωνα με καλά ενημερωμένη πηγή, από την επεξεργασία του προέκυψε ότι
|
||||||
|
οι δράστες της επίθεσης ήταν δύο, καθώς και ότι προσέγγισαν και αποχώρησαν
|
||||||
|
από το σημείο με μοτοσικλέτα.''',
|
||||||
"Η υποδομή καταλυμάτων στην Ελλάδα είναι πλήρης και ανανεώνεται συνεχώς.",
|
"Η υποδομή καταλυμάτων στην Ελλάδα είναι πλήρης και ανανεώνεται συνεχώς.",
|
||||||
"Το επείγον ταχυδρομείο (ήτοι το παραδοτέο εντός 48 ωρών το πολύ) μπορεί να μεταφέρεται αεροπορικώς μόνον εφόσον εφαρμόζονται οι κανόνες ασφαλείας.",
|
'''Το επείγον ταχυδρομείο (ήτοι το παραδοτέο εντός 48 ωρών το πολύ) μπορεί
|
||||||
"Στις ορεινές περιοχές του νησιού οι χιονοπτώσεις και οι παγετοί είναι περιορισμένοι ενώ στις παραθαλάσσιες περιοχές σημειώνονται σπανίως."
|
να μεταφέρεται αεροπορικώς μόνον εφόσον εφαρμόζονται οι κανόνες
|
||||||
|
ασφαλείας''',
|
||||||
|
''''Στις ορεινές περιοχές του νησιού οι χιονοπτώσεις και οι παγετοί είναι
|
||||||
|
περιορισμένοι ενώ στις παραθαλάσσιες περιοχές σημειώνονται σπανίως.'''
|
||||||
]
|
]
|
||||||
|
|
|
@ -5,19 +5,29 @@ from __future__ import unicode_literals
|
||||||
ADJECTIVES_IRREG = {
|
ADJECTIVES_IRREG = {
|
||||||
"χειρότερος": ("κακός",),
|
"χειρότερος": ("κακός",),
|
||||||
"χειρότερη": ("κακός",),
|
"χειρότερη": ("κακός",),
|
||||||
|
"χειρότερης": ("κακός",),
|
||||||
"χειρότερο": ("κακός",),
|
"χειρότερο": ("κακός",),
|
||||||
|
"χειρότεροι": ("κακός",),
|
||||||
|
"χειρότερων": ("κακός",),
|
||||||
|
"χειρότερου": ("κακός",),
|
||||||
"βέλτιστος": ("καλός",),
|
"βέλτιστος": ("καλός",),
|
||||||
"βέλτιστη": ("καλός",),
|
"βέλτιστη": ("καλός",),
|
||||||
|
"βέλτιστης": ("καλός",),
|
||||||
"βέλτιστο": ("καλός",),
|
"βέλτιστο": ("καλός",),
|
||||||
"βέλτιστοι": ("καλός",),
|
"βέλτιστοι": ("καλός",),
|
||||||
"βέλτιστων": ("καλός",),
|
"βέλτιστων": ("καλός",),
|
||||||
|
"βέλτιστου": ("καλός",),
|
||||||
"ελάχιστος": ("λίγος",),
|
"ελάχιστος": ("λίγος",),
|
||||||
"ελάχιστα": ("λίγος",),
|
"ελάχιστα": ("λίγος",),
|
||||||
"ελάχιστοι": ("λίγος",),
|
"ελάχιστοι": ("λίγος",),
|
||||||
"ελάχιστων": ("λίγος",),
|
"ελάχιστων": ("λίγος",),
|
||||||
"ελάχιστη": ("λίγος",),
|
"ελάχιστη": ("λίγος",),
|
||||||
|
"ελάχιστης": ("λίγος",),
|
||||||
"ελάχιστο": ("λίγος",),
|
"ελάχιστο": ("λίγος",),
|
||||||
|
"ελάχιστου": ("λίγος",),
|
||||||
"πλείστος": ("πολύς",),
|
"πλείστος": ("πολύς",),
|
||||||
|
"πλείστου": ("πολύς",),
|
||||||
|
"πλείστων": ("πολύς",),
|
||||||
"πολλή": ("πολύ",),
|
"πολλή": ("πολύ",),
|
||||||
"πολύς": ("πολύ",),
|
"πολύς": ("πολύ",),
|
||||||
"πολλύ": ("πολύ",),
|
"πολλύ": ("πολύ",),
|
||||||
|
|
|
@ -3,94 +3,148 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
|
|
||||||
ADJECTIVE_RULES = [
|
ADJECTIVE_RULES = [
|
||||||
["οί","ός"], # καρδιακοί
|
["οί", "ός"], # καρδιακοί -> καρδιακός. Ονομαστική πλ. σε -ός. (m)
|
||||||
["ές","ός"], # επιφανειακές
|
["ών", "ός"], # καρδιακών -> καρδιακός. Γενική πλ. σε -ός. (m)
|
||||||
["ές","ος"], # καρδιακές
|
["ού", "ός"], # καρδιακού -> καρδιακός. Γενική εν. σε -ός. (m)
|
||||||
["ές","ύς"], # πολλές
|
["ή", "ός"], # καρδιακή -> καρδιακός. Ονομαστική εν. σε -ή. (f)
|
||||||
["οι","ος"],
|
["ής", "ός"], # καρδιακής -> καρδιακός. Γενική εν. σε -ή. (f)
|
||||||
["αία","ος"], # ωραία
|
["ές", "ός"], # καρδιακές -> καρδιακός. Ονομαστική πλ. σε -ή. (f)
|
||||||
["ωδη","ες"], # δασώδη
|
["οι", "ος"], # ωραίοι -> ωραίος. Ονομαστική πλ. σε -ος. (m)
|
||||||
["ώδη","ες"],
|
["ων", "ος"], # ωραίων -> ωραίος. Γενική πλ. σε -ος. (m)
|
||||||
["ότερη","ός"],
|
["ου", "ος"], # ωραίου -> ωραίος. Γενική εν. σε -ος. (m)
|
||||||
["ότερος","ός"],
|
["ο", "ος"], # ωραίο -> ωραίος. Ονομαστική εν. σε -ο. (n)
|
||||||
["ότεροι", "ός"],
|
["α", "ος"], # χυδαία -> χυδαίος. Ονομαστική πλ. σε -ο. (n)
|
||||||
["ότερων","ός"],
|
["ώδη", "ώδες"], # δασώδη -> δασώδες. Ονομαστική πλ. σε -ώδες. (n)
|
||||||
["ότερες", "ός"],
|
["ύτερη", "ός"], # καλύτερη -> καλός. Συγκριτικός βαθμός σε -ή. (f)
|
||||||
|
["ύτερης", "ός"], # καλύτερης -> καλός. (f)
|
||||||
|
["ύτερων", "ός"], # καλύτερων -> καλός. (f)
|
||||||
|
["ύτερος", "ός"], # καλύτερος -> καλός. Συγκριτικός βαθμός σε -ός. (m)
|
||||||
|
["ύτερου", "ός"], # καλύτερου -> καλός. (m)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
# masculine -> m, feminine -> f, neuter -> n.
|
||||||
NOUN_RULES = [
|
NOUN_RULES = [
|
||||||
["ιά","ί"], # παιδιά
|
["ιού", "ί"], # παιδιού -> παιδί. Γενική ενικού σε -ί. (n)
|
||||||
["ια","ι"], # ποτήρια
|
["ιά", "ί"], # παιδιά -> παιδί. Ονομαστική πληθυντικού σε -ί. (n)
|
||||||
["ες","α"], # κεραμίδες
|
["ιών", "ί"], # παιδιών -> παιδί. Γενική πληθυντικού σε -ί. (n)
|
||||||
["ές","ά"],
|
["ηριού", "ήρι"], # ποτηριού -> ποτήρι. Γενική ενικού σε -ι. (n)
|
||||||
["ές","ά"],
|
["ια", "ι"], # ποτήρια -> ποτήρι. Ονομαστική πληθυντικού σε -ι. (n)
|
||||||
["ες","α"], # εσπερινές
|
["ηριών", "ήρι"], # ποτηριών -> ποτήρι. Γενική πληθυντικού σε -ι. (n)
|
||||||
["ες","η"], # ζάχαρη
|
["ας", "α"], # κεραμίδας -> κεραμίδα. Γενική ενικού σε -α. (f)
|
||||||
["ές","ή"], # φυλακές
|
["ες", "α"], # κεραμίδες -> κεραμίδα. Ονομαστική πληθυντικού σε -α. (f)
|
||||||
["ές","ής"], # καθηγητής
|
["ων", "α"], # κεραμίδων -> κεραμίδα. Γενική πληθυντικού σε -α. (f)
|
||||||
["α","ο"], # πρόβατα
|
["άς", "ά"], # βελανιδιάς -> βελανιδιά. Γενική ενικού σε -ά. (f)
|
||||||
["α","α"], # ζήτημα
|
["ές", "ά"], # βελανιδιές -> βελανιδιά. Ονομαστική πληθυντικού σε -ά. (f)
|
||||||
["ατα","α"], # στόματα
|
["ών", "ά"], # βελανιδιών -> βελανιδιά. Γενική πληθυντικού σε -ά. (f)
|
||||||
["άτα","άτα"], # ντομάτα
|
["ής", "ή"], # φυλακής -> φυλακή. Γενική ενικού σε -ή. (f)
|
||||||
["άτες","άτα"], # πατάτες
|
["ές", "ή"], # φυλακές -> φυλακή. Ονομαστική πληθυντικού σε -ή. (f)
|
||||||
["ία","ία"],
|
["ών", "ή"], # φυλακών -> φυλακή. Γενική πληθυντικού σε -ή. (f)
|
||||||
["ιά","ιά"],
|
["ές", "ής"], # καθηγητές -> καθηγητής. Ονομαστική πληθυντικού σε -ής. (m)
|
||||||
["οί","ός"], # υπουργοί
|
["ών", "ής"], # καθηγητών -> καθηγητής. Γενική πληθυντικού σε -ής. (m)
|
||||||
["ίας","ία"], # δικτατορίας, δυσωδείας, τρομοκρατίας
|
["ου", "ο"], # προβάτου -> πρόβατο. Γενική ενικού σε -ο. (n)
|
||||||
["άτων","ατα"], # δικαιωμάτων
|
["α", "ο"], # πρόβατα -> πρόβατο. Ονομαστική πληθυντικού σε -o. (n)
|
||||||
["ώπων","ωπος"], # ανθρώπων
|
["ων", "ο"], # προβάτων -> πρόβατο. Γενική πληθυντικού σε -ο. (n)
|
||||||
|
["ητήματος", "ήτημα"], # ζητήματος -> ζήτημα. Γενική ενικού σε -α (n)
|
||||||
|
# ζητήματα -> ζήτημα. Ονομαστική πληθυντικού σε -α. (n)
|
||||||
|
["ητήματα", "ήτημα"],
|
||||||
|
# ζητημάτων -> ζήτημα. Γενική πληθυντικού σε -α. (n)
|
||||||
|
["ητημάτων", "ήτημα"],
|
||||||
|
["τος", ""], # στόματος -> στόμα. Γενική ενικού σε -α. (n)
|
||||||
|
["τα", "α"], # στόματα -> στόμα. Ονομαστική πληθυντικού σε -α. (n)
|
||||||
|
["ομάτων", "όμα"], # στομάτων -> στόμα. Γενική πληθυντικού σε -α. (n)
|
||||||
|
["ού", "ός"], # υπουργού -> υπουργός. Γενική ενικού σε -ος. (m)
|
||||||
|
["οί", "ός"], # υπουργοί -> υπουργούς. Ονομαστική πληυθυντικού σε -ος. (m)
|
||||||
|
["ών", "ός"], # υπουργών -> υπουργός. Γενική πληθυντικού σε -ος. (m)
|
||||||
|
["ς", ""], # δικτατορίας -> δικτατορία. Γενική ενικού σε -ας. (f)
|
||||||
|
# δικτατορίες -> δικτατορία. Ονομαστική πληθυντικού σε -ας. (f)
|
||||||
|
["ες", "α"],
|
||||||
|
["ιών", "ία"], # δικτατοριών -> δικτατορία. Γενική πληθυντικού σε -ας. (f)
|
||||||
|
["α", "ας"], # βασιλιά -> βασιλιάς. Γενική ενικού σε -άς. (m)
|
||||||
|
["δων", ""], # βασιλιάδων -> βασιλιά. Γενική πληθυντικού σε -άς. (m)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
VERB_RULES = [
|
VERB_RULES = [
|
||||||
["εις", "ω"],
|
["εις", "ω"], # πάρεις -> πάρω. Ενεστώτας ρήματος σε -ω.
|
||||||
["εις","ώ"],
|
|
||||||
["ει", "ω"],
|
["ει", "ω"],
|
||||||
["ει","ώ"],
|
|
||||||
["ουμε", "ω"],
|
["ουμε", "ω"],
|
||||||
["ουμε","ώ"],
|
|
||||||
["ούμε","ώ"], # θεώρησα
|
|
||||||
["ούνε","ώ"], #
|
|
||||||
["ετε", "ω"],
|
["ετε", "ω"],
|
||||||
["ετε","ώ"],
|
["ουνε", "ω"],
|
||||||
["ουν", "ω"],
|
["ουν", "ω"],
|
||||||
["ουν","ώ"],
|
["είς", "ώ"], # πονείς -> πονώ. Ενεστώτας ρήματος σε -ώ vol1.
|
||||||
["είς","ώ"],
|
["εί", "ώ"], # οι κανόνες που λείπουν καλύπτονται από το αγαπώ.
|
||||||
["εί","ώ"],
|
|
||||||
["ούν", "ώ"],
|
["ούν", "ώ"],
|
||||||
["εσαι","ομαι"], #αισθάνεσαι
|
["εσαι", "ομαι"], # αισθάνεσαι -> αισθάνομαι. Ενεστώτας ρήματος σε -ομαι.
|
||||||
["εσαι","όμαι"],
|
|
||||||
["έσαι","ομαι"],
|
|
||||||
["έσαι","όμαι"],
|
|
||||||
["εται", "ομαι"],
|
["εται", "ομαι"],
|
||||||
["εται","όμαι"],
|
["ανόμαστε", "άνομαι"],
|
||||||
["έται","ομαι"],
|
["εστε", "ομαι"],
|
||||||
["έται","όμαι"],
|
["ονται", "ομαι"],
|
||||||
["όμαστε","όμαι"],
|
["άς", "ώ"], # αγαπάς -> αγαπάω (ή αγαπώ). Ενεστώτας ρήματος σε -ώ vol2.
|
||||||
["όμαστε","ομαι"],
|
|
||||||
["έσθε","όμαι"],
|
|
||||||
["εσθε","όμαι"],
|
|
||||||
["άς","ώ"], # αγαπάς
|
|
||||||
["άει", "ώ"],
|
["άει", "ώ"],
|
||||||
["άμε", "ώ"],
|
["άμε", "ώ"],
|
||||||
["άτε", "ώ"],
|
["άτε", "ώ"],
|
||||||
["άνε", "ώ"],
|
["άνε", "ώ"],
|
||||||
["άν", "ώ"],
|
["άν", "ώ"],
|
||||||
["άμε","ώ"],
|
["άω", "ώ"],
|
||||||
["άω","ώ"], # _verbs.py could contain any of the two
|
|
||||||
["ώ", "άω"],
|
["ώ", "άω"],
|
||||||
["όμουν", "ομαι"], # ζαλιζόμουν
|
# ζαλιζόμουν -> ζαλίζομαι. Παρατατικός ρήματος -ίζομαι.
|
||||||
["όμουν", "όμαι"],
|
["ιζόμουν", "ίζομαι"],
|
||||||
["όμουν", "αμαι"], # κοιμόμουν
|
["ιζόσουν", "ίζομαι"],
|
||||||
["όμουν", "αμαι"],
|
["ιζόταν", "ίζομαι"],
|
||||||
["ούσα", "ώ"], # ζητούσα -> ζητώ
|
["ιζόμασταν", "ίζομαι"],
|
||||||
|
["ιζόσασταν", "ίζομαι"],
|
||||||
|
["ονταν", "ομαι"],
|
||||||
|
["όμουν", "άμαι"], # κοιμόμουν -> κοιμάμαι. Παρατατικός ρήματος σε -άμαι.
|
||||||
|
["όσουν", "άμαι"],
|
||||||
|
["όταν", "άμαι"],
|
||||||
|
["όμασταν", "άμαι"],
|
||||||
|
["όσασταν", "άμαι"],
|
||||||
|
["όντουσταν", "άμαι"],
|
||||||
|
["ούσα", "ώ"], # ζητούσα -> ζητώ. # Παρατατικός ρήματος σε -ώ.
|
||||||
["ούσες", "ώ"],
|
["ούσες", "ώ"],
|
||||||
["ούσε", "ώ"],
|
["ούσε", "ώ"],
|
||||||
["ούσαμε", "ώ"],
|
["ούσαμε", "ώ"],
|
||||||
["ούσατε", "ώ"],
|
["ούσατε", "ώ"],
|
||||||
["ούσαν", "ώ"],
|
["ούσαν", "ώ"],
|
||||||
["ούσανε", "ώ"],
|
["ούσανε", "ώ"],
|
||||||
|
["λαμε", "ζω"], # βγάλαμε -> βγάζω. Αόριστος ρήματος σε -ω vol1.
|
||||||
|
["λατε", "ζω"],
|
||||||
|
["ήρα", "άρω"], # πήρα -> πάρω. Αόριστος ρήματος σε -ω vol2.
|
||||||
|
["ήρες", "άρω"],
|
||||||
|
["ήρε", "άρω"],
|
||||||
|
["ήραμε", "άρω"],
|
||||||
|
["ήρατε", "άρω"],
|
||||||
|
["ήρα", "άρω"],
|
||||||
|
["ένησα", "ενώ"], # φιλοξένησα -> φιλοξενώ. Αόριστος ρήματος σε -ώ vol1.
|
||||||
|
["ένησες", "ενώ"],
|
||||||
|
["ένησε", "ενώ"],
|
||||||
|
["ενήσαμε", "ενώ"],
|
||||||
|
["ένησατε", "ενώ"],
|
||||||
|
["ένησαν", "ενώ"],
|
||||||
|
["όνεσα", "ονώ"], # πόνεσα -> πονώ. Αόριστος ρήματος σε -ώ vol2.
|
||||||
|
["όνεσες", "ονώ"],
|
||||||
|
["όνεσε", "ονώ"],
|
||||||
|
["έσαμε", "ώ"],
|
||||||
|
["έσατε", "ώ"],
|
||||||
|
["ισα", "ομαι"], # κάθισα -> κάθομαι. Αόριστος ρήματος σε -ομαι.
|
||||||
|
["ισες", "ομαι"],
|
||||||
|
["ισε", "ομαι"],
|
||||||
|
["αθίσαμε", "άθομαι"],
|
||||||
|
["αθίσατε", "άθομαι"],
|
||||||
|
["ισαν", "ομαι"],
|
||||||
|
["άπα", "απώ"], # αγάπα -> αγαπώ. Προστακτική ρήματος σε -άω/ώ vol1.
|
||||||
|
["ά", "ώ"], # τιμά -> τιμώ. Προστακτική ρήματος σε άω/ώ vol2.
|
||||||
|
["οντας", "ω"], # βλέποντας -> βλέπω. Μετοχή.
|
||||||
|
["ξω", "ζω"], # παίξω -> παίζω. Μέλλοντας σε -ω.
|
||||||
|
["ξεις", "ζω"],
|
||||||
|
["ξουμε", "ζω"],
|
||||||
|
["ξετε", "ζω"],
|
||||||
|
["ξουν", "ζω"],
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,8 @@ VERBS_IRREG = {
|
||||||
"είπατε": ("λέω",),
|
"είπατε": ("λέω",),
|
||||||
"είπαν": ("λέω",),
|
"είπαν": ("λέω",),
|
||||||
"είπανε": ("λέω",),
|
"είπανε": ("λέω",),
|
||||||
|
"πει": ("λέω"),
|
||||||
|
"πω": ("λέω"),
|
||||||
"πάω": ("πηγαίνω",),
|
"πάω": ("πηγαίνω",),
|
||||||
"πάς": ("πηγαίνω",),
|
"πάς": ("πηγαίνω",),
|
||||||
"πας": ("πηγαίνω",),
|
"πας": ("πηγαίνω",),
|
||||||
|
@ -52,6 +54,7 @@ VERBS_IRREG = {
|
||||||
"είχαμε": ("έχω",),
|
"είχαμε": ("έχω",),
|
||||||
"είχατε": ("έχω",),
|
"είχατε": ("έχω",),
|
||||||
"είχαν": ("έχω",),
|
"είχαν": ("έχω",),
|
||||||
|
"είχανε": ("έχω",),
|
||||||
"έπαιρνα": ("παίρνω",),
|
"έπαιρνα": ("παίρνω",),
|
||||||
"έπαιρνες": ("παίρνω",),
|
"έπαιρνες": ("παίρνω",),
|
||||||
"έπαιρνε": ("παίρνω",),
|
"έπαιρνε": ("παίρνω",),
|
||||||
|
@ -72,6 +75,12 @@ VERBS_IRREG = {
|
||||||
"έβλεπες": ("βλέπω",),
|
"έβλεπες": ("βλέπω",),
|
||||||
"έβλεπε": ("βλέπω",),
|
"έβλεπε": ("βλέπω",),
|
||||||
"έβλεπαν": ("βλέπω",),
|
"έβλεπαν": ("βλέπω",),
|
||||||
|
"είδα": ("βλέπω",),
|
||||||
|
"είδες": ("βλέπω",),
|
||||||
|
"είδε": ("βλέπω",),
|
||||||
|
"είδαμε": ("βλέπω",),
|
||||||
|
"είδατε": ("βλέπω",),
|
||||||
|
"είδαν": ("βλέπω",),
|
||||||
"έφερνα": ("φέρνω",),
|
"έφερνα": ("φέρνω",),
|
||||||
"έφερνες": ("φέρνω",),
|
"έφερνες": ("φέρνω",),
|
||||||
"έφερνε": ("φέρνω",),
|
"έφερνε": ("φέρνω",),
|
||||||
|
@ -122,6 +131,10 @@ VERBS_IRREG = {
|
||||||
"έπεφτες": ("πέφτω",),
|
"έπεφτες": ("πέφτω",),
|
||||||
"έπεφτε": ("πέφτω",),
|
"έπεφτε": ("πέφτω",),
|
||||||
"έπεφταν": ("πέφτω",),
|
"έπεφταν": ("πέφτω",),
|
||||||
|
"έπεσα": ("πέφτω",),
|
||||||
|
"έπεσες": ("πέφτω",),
|
||||||
|
"έπεσε": ("πέφτω",),
|
||||||
|
"έπεσαν": ("πέφτω",),
|
||||||
"έστειλα": ("στέλνω",),
|
"έστειλα": ("στέλνω",),
|
||||||
"έστειλες": ("στέλνω",),
|
"έστειλες": ("στέλνω",),
|
||||||
"έστειλε": ("στέλνω",),
|
"έστειλε": ("στέλνω",),
|
||||||
|
@ -142,6 +155,12 @@ VERBS_IRREG = {
|
||||||
"έπινες": ("πίνω",),
|
"έπινες": ("πίνω",),
|
||||||
"έπινε": ("πίνω",),
|
"έπινε": ("πίνω",),
|
||||||
"έπιναν": ("πίνω",),
|
"έπιναν": ("πίνω",),
|
||||||
|
"ήπια": ("πίνω",),
|
||||||
|
"ήπιες": ("πίνω",),
|
||||||
|
"ήπιε": ("πίνω",),
|
||||||
|
"ήπιαμε": ("πίνω",),
|
||||||
|
"ήπιατε": ("πίνω",),
|
||||||
|
"ήπιαν": ("πίνω",),
|
||||||
"ετύχα": ("τυχαίνω",),
|
"ετύχα": ("τυχαίνω",),
|
||||||
"ετύχες": ("τυχαίνω",),
|
"ετύχες": ("τυχαίνω",),
|
||||||
"ετύχε": ("τυχαίνω",),
|
"ετύχε": ("τυχαίνω",),
|
||||||
|
@ -159,4 +178,23 @@ VERBS_IRREG = {
|
||||||
"τρώγατε": ("τρώω",),
|
"τρώγατε": ("τρώω",),
|
||||||
"τρώγανε": ("τρώω",),
|
"τρώγανε": ("τρώω",),
|
||||||
"τρώγαν": ("τρώω",),
|
"τρώγαν": ("τρώω",),
|
||||||
|
"πέρασα": ("περνώ",),
|
||||||
|
"πέρασες": ("περνώ",),
|
||||||
|
"πέρασε": ("περνώ",),
|
||||||
|
"πέρασαμε": ("περνώ",),
|
||||||
|
"πέρασατε": ("περνώ",),
|
||||||
|
"πέρασαν": ("περνώ",),
|
||||||
|
"έγδαρα": ("γδάρω",),
|
||||||
|
"έγδαρες": ("γδάρω",),
|
||||||
|
"έγδαρε": ("γδάρω",),
|
||||||
|
"έγδαραν": ("γδάρω",),
|
||||||
|
"έβγαλα": ("βγάλω",),
|
||||||
|
"έβγαλες": ("βγάλω",),
|
||||||
|
"έβγαλε": ("βγάλω",),
|
||||||
|
"έβγαλαν": ("βγάλω",),
|
||||||
|
"έφθασα": ("φτάνω",),
|
||||||
|
"έφθασες": ("φτάνω",),
|
||||||
|
"έφθασε": ("φτάνω",),
|
||||||
|
"έφθασαν": ("φτάνω",),
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
69
spacy/lang/el/lemmatizer/lemmatizer.py
Normal file
69
spacy/lang/el/lemmatizer/lemmatizer.py
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
# coding: utf8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from ....symbols import NOUN, VERB, ADJ, PUNCT
|
||||||
|
|
||||||
|
'''
|
||||||
|
Greek language lemmatizer applies the default rule based lemmatization
|
||||||
|
procedure with some modifications for better Greek language support.
|
||||||
|
|
||||||
|
The first modification is that it checks if the word for lemmatization is
|
||||||
|
already a lemma and if yes, it just returns it.
|
||||||
|
The second modification is about removing the base forms function which is
|
||||||
|
not applicable for Greek language.
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
class GreekLemmatizer(object):
|
||||||
|
@classmethod
|
||||||
|
def load(cls, path, index=None, exc=None, rules=None, lookup=None):
|
||||||
|
return cls(index, exc, rules, lookup)
|
||||||
|
|
||||||
|
def __init__(self, index=None, exceptions=None, rules=None, lookup=None):
|
||||||
|
self.index = index
|
||||||
|
self.exc = exceptions
|
||||||
|
self.rules = rules
|
||||||
|
self.lookup_table = lookup if lookup is not None else {}
|
||||||
|
|
||||||
|
def __call__(self, string, univ_pos, morphology=None):
|
||||||
|
if not self.rules:
|
||||||
|
return [self.lookup_table.get(string, string)]
|
||||||
|
if univ_pos in (NOUN, 'NOUN', 'noun'):
|
||||||
|
univ_pos = 'noun'
|
||||||
|
elif univ_pos in (VERB, 'VERB', 'verb'):
|
||||||
|
univ_pos = 'verb'
|
||||||
|
elif univ_pos in (ADJ, 'ADJ', 'adj'):
|
||||||
|
univ_pos = 'adj'
|
||||||
|
elif univ_pos in (PUNCT, 'PUNCT', 'punct'):
|
||||||
|
univ_pos = 'punct'
|
||||||
|
else:
|
||||||
|
return list(set([string.lower()]))
|
||||||
|
lemmas = lemmatize(string, self.index.get(univ_pos, {}),
|
||||||
|
self.exc.get(univ_pos, {}),
|
||||||
|
self.rules.get(univ_pos, []))
|
||||||
|
return lemmas
|
||||||
|
|
||||||
|
|
||||||
|
def lemmatize(string, index, exceptions, rules):
|
||||||
|
string = string.lower()
|
||||||
|
forms = []
|
||||||
|
if (string in index):
|
||||||
|
forms.append(string)
|
||||||
|
return forms
|
||||||
|
forms.extend(exceptions.get(string, []))
|
||||||
|
oov_forms = []
|
||||||
|
if not forms:
|
||||||
|
for old, new in rules:
|
||||||
|
if string.endswith(old):
|
||||||
|
form = string[:len(string) - len(old)] + new
|
||||||
|
if not form:
|
||||||
|
pass
|
||||||
|
elif form in index or not form.isalpha():
|
||||||
|
forms.append(form)
|
||||||
|
else:
|
||||||
|
oov_forms.append(form)
|
||||||
|
if not forms:
|
||||||
|
forms.extend(oov_forms)
|
||||||
|
if not forms:
|
||||||
|
forms.append(string)
|
||||||
|
return list(set(forms))
|
|
@ -4,14 +4,20 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from ...attrs import LIKE_NUM
|
from ...attrs import LIKE_NUM
|
||||||
|
|
||||||
_num_words = ['μηδέν', 'ένας', 'δυο', 'δυό', 'τρεις', 'τέσσερις', 'πέντε', 'έξι', 'εφτά', 'επτά', 'οκτώ', 'οχτώ',
|
_num_words = ['μηδέν', 'ένας', 'δυο', 'δυό', 'τρεις', 'τέσσερις', 'πέντε',
|
||||||
'εννιά', 'εννέα', 'δέκα', 'έντεκα', 'ένδεκα', 'δώδεκα', 'δεκατρείς', 'δεκατέσσερις', 'δεκαπέντε',
|
'έξι', 'εφτά', 'επτά', 'οκτώ', 'οχτώ',
|
||||||
'δεκαέξι', 'δεκαεπτά', 'δεκαοχτώ', 'δεκαεννέα', 'δεκαεννεα', 'είκοσι', 'τριάντα', 'σαράντα', 'πενήντα',
|
'εννιά', 'εννέα', 'δέκα', 'έντεκα', 'ένδεκα', 'δώδεκα',
|
||||||
'εξήντα', 'εβδομήντα', 'ογδόντα', 'ενενήντα', 'εκατό', 'διακόσιοι', 'διακόσοι', 'τριακόσιοι', 'τριακόσοι',
|
'δεκατρείς', 'δεκατέσσερις', 'δεκαπέντε', 'δεκαέξι', 'δεκαεπτά',
|
||||||
'τετρακόσιοι', 'τετρακόσοι', 'πεντακόσιοι', 'πεντακόσοι', 'εξακόσιοι', 'εξακόσοι', 'εφτακόσιοι',
|
'δεκαοχτώ', 'δεκαεννέα', 'δεκαεννεα', 'είκοσι', 'τριάντα',
|
||||||
'εφτακόσοι', 'επτακόσιοι', 'επτακόσοι', 'οχτακόσιοι', 'οχτακόσοι', 'οκτακόσιοι', 'οκτακόσοι',
|
'σαράντα', 'πενήντα', 'εξήντα', 'εβδομήντα', 'ογδόντα',
|
||||||
'εννιακόσιοι', 'χίλιοι', 'χιλιάδα', 'εκατομμύριο', 'δισεκατομμύριο', 'τρισεκατομμύριο', 'τετράκις',
|
'ενενήντα', 'εκατό', 'διακόσιοι', 'διακόσοι', 'τριακόσιοι',
|
||||||
'πεντάκις', 'εξάκις', 'επτάκις', 'οκτάκις', 'εννεάκις', 'ένα', 'δύο', 'τρία', 'τέσσερα', 'δις', 'χιλιάδες']
|
'τριακόσοι', 'τετρακόσιοι', 'τετρακόσοι', 'πεντακόσιοι',
|
||||||
|
'πεντακόσοι', 'εξακόσιοι', 'εξακόσοι', 'εφτακόσιοι', 'εφτακόσοι',
|
||||||
|
'επτακόσιοι', 'επτακόσοι', 'οχτακόσιοι', 'οχτακόσοι',
|
||||||
|
'οκτακόσιοι', 'οκτακόσοι', 'εννιακόσιοι', 'χίλιοι', 'χιλιάδα',
|
||||||
|
'εκατομμύριο', 'δισεκατομμύριο', 'τρισεκατομμύριο', 'τετράκις',
|
||||||
|
'πεντάκις', 'εξάκις', 'επτάκις', 'οκτάκις', 'εννεάκις', 'ένα',
|
||||||
|
'δύο', 'τρία', 'τέσσερα', 'δις', 'χιλιάδες']
|
||||||
|
|
||||||
|
|
||||||
def like_num(text):
|
def like_num(text):
|
||||||
|
|
|
@ -11,7 +11,6 @@ _exc={
|
||||||
"αγιορίτης": "αγιορείτης",
|
"αγιορίτης": "αγιορείτης",
|
||||||
"αγόρι": "αγώρι",
|
"αγόρι": "αγώρι",
|
||||||
"έωλος": "αίολος",
|
"έωλος": "αίολος",
|
||||||
"αητός": "αϊτός",
|
|
||||||
"αλλοίθωρος": "αλλήθωρος",
|
"αλλοίθωρος": "αλλήθωρος",
|
||||||
"αλλοιώς": "αλλιώς",
|
"αλλοιώς": "αλλιώς",
|
||||||
"αλλοιώτικος": "αλλκότικος",
|
"αλλοιώτικος": "αλλκότικος",
|
||||||
|
@ -43,17 +42,16 @@ _exc={
|
||||||
"γκάµα": "γκάµµα",
|
"γκάµα": "γκάµµα",
|
||||||
"γλύφω": "γλείφω",
|
"γλύφω": "γλείφω",
|
||||||
"γλήνα": "γλίνα",
|
"γλήνα": "γλίνα",
|
||||||
"γρικώ": "γρθικώ",
|
|
||||||
"διαφήµηση": "διαφήµιση",
|
"διαφήµηση": "διαφήµιση",
|
||||||
"δικλείδα": "δικλίδα",
|
"δικλείδα": "δικλίδα",
|
||||||
"διοξείδιο": "διοξίδιο",
|
"διοξείδιο": "διοξίδιο",
|
||||||
"διορία": "διωρία",
|
"διορία": "διωρία",
|
||||||
"δυόροφος": "διώροφος",
|
"δυόροφος": "διώροφος",
|
||||||
"δυόµισυ διόσµος": "δυόµισι",
|
"δυόµισυ": "δυόµισι",
|
||||||
"δυσφήµιση": "δυόσµος",
|
"διόσµος": "δυόσμος",
|
||||||
"δοσίλογος": "δυσφήµηση",
|
"δυσφήμιση": "δυσφήµηση",
|
||||||
"εγχείριση": "δωσίλογος",
|
"δοσίλογος": "δωσίλογος",
|
||||||
"ιδερός": "εγχείρηση",
|
"εγχείριση": "εγχείρηση",
|
||||||
"ειδωλολατρεία": "ειδωλολατρία",
|
"ειδωλολατρεία": "ειδωλολατρία",
|
||||||
"εληά": "ελιά",
|
"εληά": "ελιά",
|
||||||
"ελιξίριο": "ελιξήριο",
|
"ελιξίριο": "ελιξήριο",
|
||||||
|
@ -69,7 +67,6 @@ _exc={
|
||||||
"ζηλειάρης": "ζηλιάρης",
|
"ζηλειάρης": "ζηλιάρης",
|
||||||
"Θεοφάνεια": "Θεοφάνια",
|
"Θεοφάνεια": "Θεοφάνια",
|
||||||
"καυγάς": "καβγάς",
|
"καυγάς": "καβγάς",
|
||||||
"κάθησα": "κάθίσα",
|
|
||||||
"καθίκι": "καθοίκι",
|
"καθίκι": "καθοίκι",
|
||||||
"καινούριος": "καινούργιος",
|
"καινούριος": "καινούργιος",
|
||||||
"κακάβι": "κακκάβι",
|
"κακάβι": "κακκάβι",
|
||||||
|
@ -84,25 +81,20 @@ _exc={
|
||||||
"κυάλια": "κιάλια",
|
"κυάλια": "κιάλια",
|
||||||
"κλύδωνας": "κλήδονας",
|
"κλύδωνας": "κλήδονας",
|
||||||
"κλωτσώ": "κλοτσώ",
|
"κλωτσώ": "κλοτσώ",
|
||||||
"κυττάζω": "κολάζω",
|
|
||||||
"κολλιτσίδα": "κολλητσίδα",
|
"κολλιτσίδα": "κολλητσίδα",
|
||||||
"κολιός": "κολθιός",
|
|
||||||
"κουκί": "κουκκί",
|
"κουκί": "κουκκί",
|
||||||
"κουλός": "κουλλός",
|
"κουλός": "κουλλός",
|
||||||
"κώχη": "κόχη",
|
|
||||||
"κρεββάτι": "κρεβάτι",
|
"κρεββάτι": "κρεβάτι",
|
||||||
"κροκόδειλος": "κροκόδιλος",
|
"κροκόδειλος": "κροκόδιλος",
|
||||||
"κοβιός": "κωβιός",
|
"κοβιός": "κωβιός",
|
||||||
"λάκισα": "λάκησα",
|
"λάκισα": "λάκησα",
|
||||||
"λιµέρι": "ληµέρι",
|
"λιµέρι": "ληµέρι",
|
||||||
"λώξυγγας": "λόξυγγας",
|
"λώξυγγας": "λόξυγγας",
|
||||||
"µαγκώνω": "µαγγώνο",
|
|
||||||
"µαγγούρα": "µαγκούρα",
|
"µαγγούρα": "µαγκούρα",
|
||||||
"µαζή": "μαζί",
|
"µαζή": "μαζί",
|
||||||
"µακρυά": "µακριά",
|
"µακρυά": "µακριά",
|
||||||
"µαµή": "µαµµή",
|
"µαµή": "µαµµή",
|
||||||
"µαµόθρεφτος": "µαµµόθρεφτος",
|
"µαµόθρεφτος": "µαµµόθρεφτος",
|
||||||
"µάνα": "μάννη",
|
|
||||||
"µίγµα": "µείγµα",
|
"µίγµα": "µείγµα",
|
||||||
"µίξη": "µείξη",
|
"µίξη": "µείξη",
|
||||||
"µετώπη": "µετόπη",
|
"µετώπη": "µετόπη",
|
||||||
|
@ -126,7 +118,6 @@ _exc={
|
||||||
"ξυπόλητος": "ξυπόλυτος",
|
"ξυπόλητος": "ξυπόλυτος",
|
||||||
"ξωκλήσι": "ξωκκλήσι",
|
"ξωκλήσι": "ξωκκλήσι",
|
||||||
"οξυά": "οξιά",
|
"οξυά": "οξιά",
|
||||||
"οξείδωση": "οξείδωση",
|
|
||||||
"ορθοπεδικός": "ορθοπαιδικός",
|
"ορθοπεδικός": "ορθοπαιδικός",
|
||||||
"ωχ": "οχ",
|
"ωχ": "οχ",
|
||||||
"παπάς": "παππάς",
|
"παπάς": "παππάς",
|
||||||
|
@ -176,7 +167,6 @@ _exc={
|
||||||
"τανίζω": "τανύζω",
|
"τανίζω": "τανύζω",
|
||||||
"τέσσερις": "τέσσερεις",
|
"τέσσερις": "τέσσερεις",
|
||||||
"τζιτζιφιά": "τζιτζυφιά",
|
"τζιτζιφιά": "τζιτζυφιά",
|
||||||
"τζιριτζάντζουλα": "τζυριτζάντζουλα",
|
|
||||||
"τόνος": "τόννος",
|
"τόνος": "τόννος",
|
||||||
"τοπείο": "τοπίο",
|
"τοπείο": "τοπίο",
|
||||||
"τρέλλα": "τρέλα",
|
"τρέλλα": "τρέλα",
|
||||||
|
@ -214,7 +204,6 @@ _exc={
|
||||||
"µυλαίδη": "µιλέδη",
|
"µυλαίδη": "µιλέδη",
|
||||||
"µποϋκοτάζ": "µποϊκοτάζ",
|
"µποϋκοτάζ": "µποϊκοτάζ",
|
||||||
"πέναλτυ": "πέναλτι",
|
"πέναλτυ": "πέναλτι",
|
||||||
"πλέυ µπόυ": "πλεϊµπόϊ",
|
|
||||||
"πορτραίτο": "πορτρέτο",
|
"πορτραίτο": "πορτρέτο",
|
||||||
"ρεστωράν": "ρεστοράν",
|
"ρεστωράν": "ρεστοράν",
|
||||||
"ροσµπήφ": "ροσµπίφ",
|
"ροσµπήφ": "ροσµπίφ",
|
||||||
|
@ -297,14 +286,8 @@ _exc={
|
||||||
"αλατένια": "αλάτινη",
|
"αλατένια": "αλάτινη",
|
||||||
"αλατένιο": "αλάτινο",
|
"αλατένιο": "αλάτινο",
|
||||||
"αλαφραίνω": "ελαφρώνω",
|
"αλαφραίνω": "ελαφρώνω",
|
||||||
"αλαφριός": "αλαφρός",
|
|
||||||
"αλαφριός": "ελαφρύς",
|
"αλαφριός": "ελαφρύς",
|
||||||
"αλαφριός": "ελαφρός",
|
|
||||||
"αλαφριά": "αλαφρή",
|
|
||||||
"αλαφριά": "ελαφριά",
|
|
||||||
"αλαφριό": "αλαφρό",
|
|
||||||
"αλαφριό": "ελαφρύ",
|
"αλαφριό": "ελαφρύ",
|
||||||
"αλαφριό": "ελαφρό",
|
|
||||||
"αλαφρόµυαλος": "ελαφρόµυαλος",
|
"αλαφρόµυαλος": "ελαφρόµυαλος",
|
||||||
"αλαφρόμυαλη": "ελαφρόμυαλη",
|
"αλαφρόμυαλη": "ελαφρόμυαλη",
|
||||||
"αλαφρόμυαλο": "ελαφρόμυαλο",
|
"αλαφρόμυαλο": "ελαφρόμυαλο",
|
||||||
|
@ -349,8 +332,6 @@ _exc={
|
||||||
"αναπτυγµένος": "ανεπτυγμένος",
|
"αναπτυγµένος": "ανεπτυγμένος",
|
||||||
"αναπτυγµένη": "ανεπτυγμένη",
|
"αναπτυγµένη": "ανεπτυγμένη",
|
||||||
"αναπτυγµένο": "ανεπτυγμένο",
|
"αναπτυγµένο": "ανεπτυγμένο",
|
||||||
"άναστρος": "ανάστερη",
|
|
||||||
"άναστρος": "ανάστερο",
|
|
||||||
"άναστρος": "ανάστερος",
|
"άναστρος": "ανάστερος",
|
||||||
"αναστυλώνω": "αναστηλώνω",
|
"αναστυλώνω": "αναστηλώνω",
|
||||||
"αναστύλωση": "αναστήλωση",
|
"αναστύλωση": "αναστήλωση",
|
||||||
|
@ -810,7 +791,6 @@ _exc={
|
||||||
"κανονιοβολώ": "καννονιοβολώ",
|
"κανονιοβολώ": "καννονιοβολώ",
|
||||||
"κανονιοστάσιο": "καννονιοστάσιο",
|
"κανονιοστάσιο": "καννονιοστάσιο",
|
||||||
"κανονιοστοιχία": "καννονιοστοιχία",
|
"κανονιοστοιχία": "καννονιοστοιχία",
|
||||||
"κανονιοφόρος": "καννονιοφόρος",
|
|
||||||
"κανονοθυρίδα": "καννονοθυρίδα",
|
"κανονοθυρίδα": "καννονοθυρίδα",
|
||||||
"κάνουλα": "κάννουλα",
|
"κάνουλα": "κάννουλα",
|
||||||
"κανών": "κανόνας",
|
"κανών": "κανόνας",
|
||||||
|
@ -1394,7 +1374,6 @@ _exc={
|
||||||
"πίστοµα": "απίστοµα",
|
"πίστοµα": "απίστοµα",
|
||||||
"πιτσιλάδα": "πιτσυλάδα",
|
"πιτσιλάδα": "πιτσυλάδα",
|
||||||
"πιτσιλιά": "πιτσυλιά",
|
"πιτσιλιά": "πιτσυλιά",
|
||||||
"πιτσιλώ": "πιτσυλίζω",
|
|
||||||
"πίττα": "πίτα",
|
"πίττα": "πίτα",
|
||||||
"πίτυρον": "πίτουρο",
|
"πίτυρον": "πίτουρο",
|
||||||
"πλάγι": "πλάι",
|
"πλάγι": "πλάι",
|
||||||
|
@ -1626,7 +1605,6 @@ _exc={
|
||||||
"σταλαµατιά": "σταλαγµατιά",
|
"σταλαµατιά": "σταλαγµατιά",
|
||||||
"σταλαξιά": "σταλαγµατιά",
|
"σταλαξιά": "σταλαγµατιά",
|
||||||
"σταλίτσα": "σταλιά",
|
"σταλίτσα": "σταλιά",
|
||||||
"σταρέµπορος": "σιταρέµπορος",
|
|
||||||
"σταρήθρα": "σιταρήθρα",
|
"σταρήθρα": "σιταρήθρα",
|
||||||
"στάρι": "σιτάρι",
|
"στάρι": "σιτάρι",
|
||||||
"σταρότοπος": "σιταρότοπος",
|
"σταρότοπος": "σιταρότοπος",
|
||||||
|
@ -1862,7 +1840,6 @@ _exc={
|
||||||
"φτηναίνω": "φθηναίνω",
|
"φτηναίνω": "φθηναίνω",
|
||||||
"φτιασίδι": "φτειασίδι",
|
"φτιασίδι": "φτειασίδι",
|
||||||
"φτιασιδώνοµαι": "φτειασιδώνοµαι",
|
"φτιασιδώνοµαι": "φτειασιδώνοµαι",
|
||||||
"φτιάχνω": "φτιάχνω",
|
|
||||||
"φτωχοκοµείο": "πτωχοκοµείο",
|
"φτωχοκοµείο": "πτωχοκοµείο",
|
||||||
"φυγάδας": "φυγάς",
|
"φυγάδας": "φυγάς",
|
||||||
"φύγω": "φεύγω",
|
"φύγω": "φεύγω",
|
||||||
|
@ -1890,7 +1867,6 @@ _exc={
|
||||||
"χάµου": "χάµω",
|
"χάµου": "χάµω",
|
||||||
"χαµψίνι": "χαµσίνι",
|
"χαµψίνι": "χαµσίνι",
|
||||||
"χάνδρα": "χάντρα",
|
"χάνδρα": "χάντρα",
|
||||||
"χάνος": "χαγάνος",
|
|
||||||
"χαντζής": "χανιτζής",
|
"χαντζής": "χανιτζής",
|
||||||
"χαραµατιά": "χαραγµατιά",
|
"χαραµατιά": "χαραγµατιά",
|
||||||
"χάραξ": "χάρακας",
|
"χάραξ": "χάρακας",
|
||||||
|
@ -2465,7 +2441,6 @@ _exc={
|
||||||
"συχωριανό": "συγχωριανό",
|
"συχωριανό": "συγχωριανό",
|
||||||
"ταγκός": "ταγγός",
|
"ταγκός": "ταγγός",
|
||||||
"ταγκή": "ταγγή",
|
"ταγκή": "ταγγή",
|
||||||
"ταγκό": "ταγγό",
|
|
||||||
"ταµιευτικός": "αποταµιευτικός",
|
"ταµιευτικός": "αποταµιευτικός",
|
||||||
"ταµιευτική": "αποταµιευτική",
|
"ταµιευτική": "αποταµιευτική",
|
||||||
"ταµιευτικό": "αποταµιευτικό",
|
"ταµιευτικό": "αποταµιευτικό",
|
||||||
|
|
|
@ -10,7 +10,11 @@ _units = ('km km² km³ m m² m³ dm dm² dm³ cm cm² cm³ mm mm² mm³ ha µm
|
||||||
'kg g mg µg t lb oz m/s km/h kmh mph hPa Pa mbar mb MB kb KB gb GB tb '
|
'kg g mg µg t lb oz m/s km/h kmh mph hPa Pa mbar mb MB kb KB gb GB tb '
|
||||||
'TB T G M K км км² км³ м м² м³ дм дм² дм³ см см² см³ мм мм² мм³ нм '
|
'TB T G M K км км² км³ м м² м³ дм дм² дм³ см см² см³ мм мм² мм³ нм '
|
||||||
'кг г мг м/с км/ч кПа Па мбар Кб КБ кб Мб МБ мб Гб ГБ гб Тб ТБ тб')
|
'кг г мг м/с км/ч кПа Па мбар Кб КБ кб Мб МБ мб Гб ГБ гб Тб ТБ тб')
|
||||||
merge_chars = lambda char: char.strip().replace(' ', '|')
|
|
||||||
|
|
||||||
|
def merge_chars(char): return char.strip().replace(' ', '|')
|
||||||
|
|
||||||
|
|
||||||
UNITS = merge_chars(_units)
|
UNITS = merge_chars(_units)
|
||||||
|
|
||||||
_prefixes = (['\'\'', '§', '%', '=', r'\+[0-9]+%', # 90%
|
_prefixes = (['\'\'', '§', '%', '=', r'\+[0-9]+%', # 90%
|
||||||
|
@ -42,7 +46,8 @@ _suffixes = (LIST_PUNCT + LIST_ELLIPSES + LIST_QUOTES + LIST_ICONS +
|
||||||
r'(?<=[Α-Ωα-ωίϊΐόάέύϋΰήώ])\.',
|
r'(?<=[Α-Ωα-ωίϊΐόάέύϋΰήώ])\.',
|
||||||
r'^[Α-Ω]{1}\.',
|
r'^[Α-Ω]{1}\.',
|
||||||
r'\ [Α-Ω]{1}\.',
|
r'\ [Α-Ω]{1}\.',
|
||||||
r'[ΈΆΊΑΌ-Ωα-ωίϊΐόάέύϋΰήώ]+([\-]([ΈΆΊΑΌ-Ωα-ωίϊΐόάέύϋΰήώ]+))+', # πρώτος-δεύτερος , πρώτος-δεύτερος-τρίτος
|
# πρώτος-δεύτερος , πρώτος-δεύτερος-τρίτος
|
||||||
|
r'[ΈΆΊΑΌ-Ωα-ωίϊΐόάέύϋΰήώ]+([\-]([ΈΆΊΑΌ-Ωα-ωίϊΐόάέύϋΰήώ]+))+',
|
||||||
r'([0-9]+)mg', # 13mg
|
r'([0-9]+)mg', # 13mg
|
||||||
r'([0-9]+)\.([0-9]+)m' # 1.2m
|
r'([0-9]+)\.([0-9]+)m' # 1.2m
|
||||||
])
|
])
|
||||||
|
@ -53,7 +58,8 @@ _infixes = (LIST_ELLIPSES + LIST_ICONS +
|
||||||
r'([0-9])+(\.([0-9]+))*([\-]([0-9])+)+', # 10.9 , 10.9.9 , 10.9-6
|
r'([0-9])+(\.([0-9]+))*([\-]([0-9])+)+', # 10.9 , 10.9.9 , 10.9-6
|
||||||
r'([0-9])+[,]([0-9])+[\-]([0-9])+[,]([0-9])+', # 10,11,12
|
r'([0-9])+[,]([0-9])+[\-]([0-9])+[,]([0-9])+', # 10,11,12
|
||||||
r'([0-9])+[ης]+([\-]([0-9])+)+', # 1ης-2
|
r'([0-9])+[ης]+([\-]([0-9])+)+', # 1ης-2
|
||||||
r'([0-9]){1,4}[\/]([0-9]){1,2}([\/]([0-9]){0,4}){0,1}', # 15/2 , 15/2/17 , 2017/2/15
|
# 15/2 , 15/2/17 , 2017/2/15
|
||||||
|
r'([0-9]){1,4}[\/]([0-9]){1,2}([\/]([0-9]){0,4}){0,1}',
|
||||||
r'[A-Za-z]+\@[A-Za-z]+(\-[A-Za-z]+)*\.[A-Za-z]+', # abc@cde-fgh.a
|
r'[A-Za-z]+\@[A-Za-z]+(\-[A-Za-z]+)*\.[A-Za-z]+', # abc@cde-fgh.a
|
||||||
r'([a-zA-Z]+)(\-([a-zA-Z]+))+', # abc-abc
|
r'([a-zA-Z]+)(\-([a-zA-Z]+))+', # abc-abc
|
||||||
r'(?<=[{}])\.(?=[{}])'.format(ALPHA_LOWER, ALPHA_UPPER),
|
r'(?<=[{}])\.(?=[{}])'.format(ALPHA_LOWER, ALPHA_UPPER),
|
||||||
|
|
61
spacy/lang/el/syntax_iterators.py
Normal file
61
spacy/lang/el/syntax_iterators.py
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
# coding: utf8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from ...symbols import NOUN, PROPN, PRON
|
||||||
|
|
||||||
|
|
||||||
|
def noun_chunks(obj):
|
||||||
|
"""
|
||||||
|
Detect base noun phrases. Works on both Doc and Span.
|
||||||
|
"""
|
||||||
|
|
||||||
|
# it follows the logic of the noun chunks finder of English language,
|
||||||
|
# adjusted to some Greek language special characteristics.
|
||||||
|
|
||||||
|
# obj tag corrects some DEP tagger mistakes.
|
||||||
|
# Further improvement of the models will eliminate the need for this tag.
|
||||||
|
labels = ['nsubj', 'obj', 'iobj', 'appos', 'ROOT', 'obl']
|
||||||
|
doc = obj.doc # Ensure works on both Doc and Span.
|
||||||
|
np_deps = [doc.vocab.strings.add(label) for label in labels]
|
||||||
|
conj = doc.vocab.strings.add('conj')
|
||||||
|
nmod = doc.vocab.strings.add('nmod')
|
||||||
|
np_label = doc.vocab.strings.add('NP')
|
||||||
|
seen = set()
|
||||||
|
for i, word in enumerate(obj):
|
||||||
|
if word.pos not in (NOUN, PROPN, PRON):
|
||||||
|
continue
|
||||||
|
# Prevent nested chunks from being produced
|
||||||
|
if word.i in seen:
|
||||||
|
continue
|
||||||
|
if word.dep in np_deps:
|
||||||
|
if any(w.i in seen for w in word.subtree):
|
||||||
|
continue
|
||||||
|
flag = False
|
||||||
|
if (word.pos == NOUN):
|
||||||
|
# check for patterns such as γραμμή παραγωγής
|
||||||
|
for potential_nmod in word.rights:
|
||||||
|
if (potential_nmod.dep == nmod):
|
||||||
|
seen.update(j for j in range(
|
||||||
|
word.left_edge.i, potential_nmod.i + 1))
|
||||||
|
yield word.left_edge.i, potential_nmod.i + 1, np_label
|
||||||
|
flag = True
|
||||||
|
break
|
||||||
|
if (flag is False):
|
||||||
|
seen.update(j for j in range(word.left_edge.i, word.i + 1))
|
||||||
|
yield word.left_edge.i, word.i + 1, np_label
|
||||||
|
elif word.dep == conj:
|
||||||
|
# covers the case: έχει όμορφα και έξυπνα παιδιά
|
||||||
|
head = word.head
|
||||||
|
while head.dep == conj and head.head.i < head.i:
|
||||||
|
head = head.head
|
||||||
|
# If the head is an NP, and we're coordinated to it, we're an NP
|
||||||
|
if head.dep in np_deps:
|
||||||
|
if any(w.i in seen for w in word.subtree):
|
||||||
|
continue
|
||||||
|
seen.update(j for j in range(word.left_edge.i, word.i + 1))
|
||||||
|
yield word.left_edge.i, word.i + 1, np_label
|
||||||
|
|
||||||
|
|
||||||
|
SYNTAX_ITERATORS = {
|
||||||
|
'noun_chunks': noun_chunks
|
||||||
|
}
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
from ...symbols import POS, PUNCT, SYM, ADJ, CCONJ, SCONJ, NUM, DET, ADV, ADP, X, VERB
|
from ...symbols import POS, PUNCT, SYM, ADJ, CCONJ, SCONJ, NUM, DET, ADV, ADP, X, VERB
|
||||||
from ...symbols import NOUN, PROPN, PART, INTJ,SPACE,PRON
|
from ...symbols import NOUN, PROPN, PART, INTJ, PRON
|
||||||
|
|
||||||
TAG_MAP = {
|
TAG_MAP = {
|
||||||
"ABBR": {POS: NOUN, "Abbr": "Yes"},
|
"ABBR": {POS: NOUN, "Abbr": "Yes"},
|
||||||
|
@ -596,4 +596,3 @@ TAG_MAP = {
|
||||||
"VbMnPpXxXxSgNePePvVo": {POS: VERB, "VerbForm": "Part", "Mood": "", "Tense": "Pres|Past", "Person": "1|2|3", "Number": "Sing", "Gender": "Neut", "Aspect": "Perf", "Voice": "Pass", "Case": "Voc"},
|
"VbMnPpXxXxSgNePePvVo": {POS: VERB, "VerbForm": "Part", "Mood": "", "Tense": "Pres|Past", "Person": "1|2|3", "Number": "Sing", "Gender": "Neut", "Aspect": "Perf", "Voice": "Pass", "Case": "Voc"},
|
||||||
"VbMnPpXxXxXxXxIpAvXx": {POS: VERB, "VerbForm": "Conv", "Mood": "", "Tense": "Pres|Past", "Person": "1|2|3", "Number": "Sing|Plur", "Gender": "Masc|Fem|Neut", "Aspect": "Imp", "Voice": "Act", "Case": "Nom|Gen|Dat|Acc|Voc"}
|
"VbMnPpXxXxXxXxIpAvXx": {POS: VERB, "VerbForm": "Conv", "Mood": "", "Tense": "Pres|Past", "Person": "1|2|3", "Number": "Sing|Plur", "Gender": "Masc|Fem|Neut", "Aspect": "Imp", "Voice": "Act", "Case": "Nom|Gen|Dat|Acc|Voc"}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from ...symbols import POS, ADV, NOUN, ADP, PRON, SCONJ, PROPN, DET, SYM, INTJ
|
from ...symbols import POS, ADV, NOUN, ADP, PRON, SCONJ, PROPN, DET, SYM, INTJ
|
||||||
from ...symbols import PUNCT, NUM, AUX, X, CONJ, ADJ, VERB, PART, SPACE, CCONJ
|
from ...symbols import PUNCT, NUM, AUX, X, ADJ, VERB, PART, SPACE, CCONJ
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
TAG_MAP = {
|
TAG_MAP = {
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from ...symbols import ORTH, LEMMA, TAG, NORM, ADP, DET
|
from ...symbols import ORTH, LEMMA, NORM
|
||||||
|
|
||||||
_exc = {}
|
_exc = {}
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,7 @@ lors lorsque lui lui-meme lui-même là lès
|
||||||
|
|
||||||
m' m’ ma maint maintenant mais malgre malgré maximale me meme memes merci mes mien
|
m' m’ ma maint maintenant mais malgre malgré maximale me meme memes merci mes mien
|
||||||
mienne miennes miens mille mince minimale moi moi-meme moi-même moindres moins
|
mienne miennes miens mille mince minimale moi moi-meme moi-même moindres moins
|
||||||
mon moyennant multiple multiples même mêmes
|
mon moyennant même mêmes
|
||||||
|
|
||||||
n' n’ na naturel naturelle naturelles ne neanmoins necessaire necessairement neuf
|
n' n’ na naturel naturelle naturelles ne neanmoins necessaire necessairement neuf
|
||||||
neuvième ni nombreuses nombreux non nos notamment notre nous nous-mêmes nouveau
|
neuvième ni nombreuses nombreux non nos notamment notre nous nous-mêmes nouveau
|
||||||
|
|
|
@ -3,9 +3,9 @@ from __future__ import unicode_literals
|
||||||
|
|
||||||
from ..norm_exceptions import BASE_NORMS
|
from ..norm_exceptions import BASE_NORMS
|
||||||
from ...attrs import NORM
|
from ...attrs import NORM
|
||||||
|
from ...attrs import LIKE_NUM
|
||||||
from ...util import add_lookups
|
from ...util import add_lookups
|
||||||
|
|
||||||
|
|
||||||
_stem_suffixes = [
|
_stem_suffixes = [
|
||||||
["ो","े","ू","ु","ी","ि","ा"],
|
["ो","े","ू","ु","ी","ि","ा"],
|
||||||
["कर","ाओ","िए","ाई","ाए","ने","नी","ना","ते","ीं","ती","ता","ाँ","ां","ों","ें"],
|
["कर","ाओ","िए","ाई","ाए","ने","नी","ना","ते","ीं","ती","ता","ाँ","ां","ों","ें"],
|
||||||
|
@ -14,6 +14,13 @@ _stem_suffixes = [
|
||||||
["ाएंगी","ाएंगे","ाऊंगी","ाऊंगा","ाइयाँ","ाइयों","ाइयां"]
|
["ाएंगी","ाएंगे","ाऊंगी","ाऊंगा","ाइयाँ","ाइयों","ाइयां"]
|
||||||
]
|
]
|
||||||
|
|
||||||
|
#reference 1:https://en.wikipedia.org/wiki/Indian_numbering_system
|
||||||
|
#reference 2: https://blogs.transparent.com/hindi/hindi-numbers-1-100/
|
||||||
|
|
||||||
|
_num_words = ['शून्य', 'एक', 'दो', 'तीन', 'चार', 'पांच', 'छह', 'सात', 'आठ', 'नौ', 'दस',
|
||||||
|
'ग्यारह', 'बारह', 'तेरह', 'चौदह', 'पंद्रह', 'सोलह', 'सत्रह', 'अठारह', 'उन्नीस',
|
||||||
|
'बीस', 'तीस', 'चालीस', 'पचास', 'साठ', 'सत्तर', 'अस्सी', 'नब्बे', 'सौ', 'हज़ार',
|
||||||
|
'लाख', 'करोड़', 'अरब', 'खरब']
|
||||||
|
|
||||||
def norm(string):
|
def norm(string):
|
||||||
# normalise base exceptions, e.g. punctuation or currency symbols
|
# normalise base exceptions, e.g. punctuation or currency symbols
|
||||||
|
@ -32,7 +39,20 @@ def norm(string):
|
||||||
return string[:-length]
|
return string[:-length]
|
||||||
return string
|
return string
|
||||||
|
|
||||||
|
def like_num(text):
|
||||||
|
text = text.replace(',', '').replace('.', '')
|
||||||
|
if text.isdigit():
|
||||||
|
return True
|
||||||
|
if text.count('/') == 1:
|
||||||
|
num, denom = text.split('/')
|
||||||
|
if num.isdigit() and denom.isdigit():
|
||||||
|
return True
|
||||||
|
if text.lower() in _num_words:
|
||||||
|
return True
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
LEX_ATTRS = {
|
LEX_ATTRS = {
|
||||||
NORM: norm
|
NORM: norm
|
||||||
|
LIKE_NUM: like_num
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,7 +10,7 @@ Example sentences to test spaCy and its language models.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
|
||||||
examples = [
|
sentences = [
|
||||||
"Apple overweegt om voor 1 miljard een U.K. startup te kopen",
|
"Apple overweegt om voor 1 miljard een U.K. startup te kopen",
|
||||||
"Autonome auto's verschuiven de verzekeringverantwoordelijkheid naar producenten",
|
"Autonome auto's verschuiven de verzekeringverantwoordelijkheid naar producenten",
|
||||||
"San Francisco overweegt robots op voetpaden te verbieden",
|
"San Francisco overweegt robots op voetpaden te verbieden",
|
||||||
|
|
|
@ -11,8 +11,41 @@ Example sentences to test spaCy and its language models.
|
||||||
|
|
||||||
|
|
||||||
sentences = [
|
sentences = [
|
||||||
|
#Translations from English:
|
||||||
"Apple рассматривает возможность покупки стартапа из Соединенного Королевства за $1 млрд",
|
"Apple рассматривает возможность покупки стартапа из Соединенного Королевства за $1 млрд",
|
||||||
"Автономные автомобили переносят страховую ответственность на производителя",
|
"Автономные автомобили переносят страховую ответственность на производителя",
|
||||||
"В Сан Франциско рассматривается возможность запрета роботов-курьеров, которые перемещаются по тротуару",
|
"В Сан Франциско рассматривается возможность запрета роботов-курьеров, которые перемещаются по тротуару",
|
||||||
"Лондон - большой город Соединенного Королевства"
|
"Лондон - большой город Соединенного Королевства",
|
||||||
|
|
||||||
|
#Native Russian sentences:
|
||||||
|
|
||||||
|
#Colloquial:
|
||||||
|
"Да, нет, наверное!",#Typical polite refusal
|
||||||
|
"Обратите внимание на необыкновенную крастоту этого города-героя Москвы, столицы нашей Родины!",#From a tour guide speech
|
||||||
|
|
||||||
|
#Examples of Bookish Russian:
|
||||||
|
"Рио-де-Жанейро — эта моя мечта и не смейте касаться ее своими грязными лапами!",#Quote from "The Golden Calf"
|
||||||
|
|
||||||
|
#Quotes from "Ivan Vasilievish changes his occupation" - a famous Russian comedy known by all Russians
|
||||||
|
"Ты пошто боярыню обидел, смерд?!!",
|
||||||
|
"Оставь меня, старушка, я в печали!",
|
||||||
|
|
||||||
|
#Quotes from Dostoevsky:
|
||||||
|
"Уж коли я, такой же, как и ты, человек грешный, над тобой умилился и пожалел тебя, кольми паче бог.",
|
||||||
|
"В мечтах я нередко, говорит, доходил до страстных помыслов о служении человечеству и может быть действительно пошел бы на крест за людей, если б это вдруг как-нибудь потребовалось, а между тем я двух дней не в состоянии прожить ни с кем в одной комнате, о чем знаю из опыта.",
|
||||||
|
"Зато всегда так происходило, что чем более я ненавидел людей в частности, тем пламеннее становилась любовь моя к человечеству вообще.",
|
||||||
|
|
||||||
|
#Quotes from Chechov:
|
||||||
|
"Ненужные дела и разговоры все об одном отхватывают на свою долю лучшую часть времени, лучшие силы, и в конце концов остается какая-то куцая, бескрылая жизнь, какая-то чепуха, и уйти и бежать нельзя, точно сидишь в сумасшедшем доме или в арестантских ротах!",
|
||||||
|
|
||||||
|
#Quotes from Turgenev:
|
||||||
|
"Нравится тебе женщина, старайся добиться толку; а нельзя - ну, не надо, отвернись - земля не клином сошлась.",
|
||||||
|
"Узенькое местечко, которое я занимаю, до того крохотно в сравнении с остальным пространством, где меня нет и где дела до меня нет; и часть времени, которую мне удастся прожить, так ничтожна перед вечностью, где меня не было и не будет...",
|
||||||
|
|
||||||
|
#Quotes from newspapers:
|
||||||
|
#Komsomolskaya Pravda:
|
||||||
|
"На заседании президиума правительства Москвы принято решение присвоить статус инвестиционного приоритетного проекта города Москвы киностудии Союзмультфильм",
|
||||||
|
"Глава Минобороны Сергей Шойгу заявил, что обстановка на этом стратегическом направлении требует непрерывного совершенствования боевого состава войск.",
|
||||||
|
#Argumeni i Facti:
|
||||||
|
"На реплику лже-Говина — дескать, он (Волков) будет лучшим революционером — Стамп с энтузиазмом ответил: Непременно!",
|
||||||
]
|
]
|
||||||
|
|
|
@ -5,15 +5,27 @@ from __future__ import unicode_literals
|
||||||
_exc = {
|
_exc = {
|
||||||
# Slang
|
# Slang
|
||||||
'прив': 'привет',
|
'прив': 'привет',
|
||||||
|
'дарова': 'привет',
|
||||||
|
'дак': 'так',
|
||||||
|
'дык': 'так',
|
||||||
|
'здарова': 'привет',
|
||||||
|
'пакедава': 'пока',
|
||||||
|
'пакедаво': 'пока',
|
||||||
'ща': 'сейчас',
|
'ща': 'сейчас',
|
||||||
'спс': 'спасибо',
|
'спс': 'спасибо',
|
||||||
'пжлст': 'пожалуйста',
|
'пжлст': 'пожалуйста',
|
||||||
'плиз': 'пожалуйста',
|
'плиз': 'пожалуйста',
|
||||||
|
'ладненько': 'ладно',
|
||||||
|
'лады': 'ладно',
|
||||||
'лан': 'ладно',
|
'лан': 'ладно',
|
||||||
'ясн': 'ясно',
|
'ясн': 'ясно',
|
||||||
'всм': 'всмысле',
|
'всм': 'всмысле',
|
||||||
'хош': 'хочешь',
|
'хош': 'хочешь',
|
||||||
'оч': 'очень'
|
'хаюшки': 'привет',
|
||||||
|
'оч': 'очень',
|
||||||
|
'че': 'что',
|
||||||
|
'чо': 'что',
|
||||||
|
'шо': 'что'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,7 @@
|
||||||
# coding: utf8
|
# coding: utf8
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from ...symbols import ORTH, LEMMA, TAG, NORM, PRON_LEMMA
|
from ...symbols import LEMMA, NORM, ORTH, PRON_LEMMA, PUNCT, TAG
|
||||||
|
|
||||||
|
|
||||||
_exc = {}
|
_exc = {}
|
||||||
|
|
||||||
|
@ -70,13 +69,25 @@ for exc_data in [
|
||||||
_exc[exc_data[ORTH]] = [exc_data]
|
_exc[exc_data[ORTH]] = [exc_data]
|
||||||
|
|
||||||
|
|
||||||
for orth in [
|
ABBREVIATIONS = [
|
||||||
"ang.", "anm.", "bil.", "bl.a.", "dvs.", "e.Kr.", "el.", "e.d.", "eng.",
|
"ang", "anm", "bil", "bl.a", "d.v.s", "doc", "dvs", "e.d", "e.kr", "el",
|
||||||
"etc.", "exkl.", "f.d.", "fid.", "f.Kr.", "forts.", "fr.o.m.", "f.ö.",
|
"eng", "etc", "exkl", "f", "f.d", "f.kr", "f.n", "f.ö", "fid", "fig",
|
||||||
"förf.", "inkl.", "jur.", "kl.", "kr.", "lat.", "m.a.o.", "max.", "m.fl.",
|
"forts", "fr.o.m", "förf", "inkl", "jur", "kap", "kl", "kor", "kr",
|
||||||
"min.", "m.m.", "obs.", "o.d.", "osv.", "p.g.a.", "ref.", "resp.", "s.a.s.",
|
"kungl", "lat", "m.a.o", "m.fl", "m.m", "max", "milj", "min", "mos",
|
||||||
"s.k.", "st.", "s:t", "t.ex.", "t.o.m.", "ung.", "äv.", "övers."]:
|
"mt", "o.d", "o.s.v", "obs", "osv", "p.g.a", "proc", "prof", "ref",
|
||||||
|
"resp", "s.a.s", "s.k", "s.t", "sid", "s:t", "t.ex", "t.h", "t.o.m", "t.v",
|
||||||
|
"tel", "ung", "vol", "äv", "övers"
|
||||||
|
]
|
||||||
|
ABBREVIATIONS = [abbr + "." for abbr in ABBREVIATIONS] + ABBREVIATIONS
|
||||||
|
|
||||||
|
for orth in ABBREVIATIONS:
|
||||||
_exc[orth] = [{ORTH: orth}]
|
_exc[orth] = [{ORTH: orth}]
|
||||||
|
|
||||||
|
# Sentences ending in "i." (as in "... peka i."), "m." (as in "...än 2000 m."),
|
||||||
|
# should be tokenized as two separate tokens.
|
||||||
|
for orth in ["i", "m"]:
|
||||||
|
_exc[orth + "."] = [
|
||||||
|
{ORTH: orth, LEMMA: orth, NORM: orth},
|
||||||
|
{ORTH: ".", TAG: PUNCT}]
|
||||||
|
|
||||||
TOKENIZER_EXCEPTIONS = _exc
|
TOKENIZER_EXCEPTIONS = _exc
|
||||||
|
|
|
@ -4,12 +4,20 @@ from __future__ import unicode_literals
|
||||||
from ...attrs import LANG
|
from ...attrs import LANG
|
||||||
from ...language import Language
|
from ...language import Language
|
||||||
from ...tokens import Doc
|
from ...tokens import Doc
|
||||||
|
from .tag_map import TAG_MAP
|
||||||
|
from .stop_words import STOP_WORDS
|
||||||
|
from ...util import update_exc
|
||||||
|
from ..tokenizer_exceptions import BASE_EXCEPTIONS
|
||||||
|
from .tokenizer_exceptions import TOKENIZER_EXCEPTIONS
|
||||||
|
|
||||||
|
|
||||||
class ChineseDefaults(Language.Defaults):
|
class ChineseDefaults(Language.Defaults):
|
||||||
lex_attr_getters = dict(Language.Defaults.lex_attr_getters)
|
lex_attr_getters = dict(Language.Defaults.lex_attr_getters)
|
||||||
lex_attr_getters[LANG] = lambda text: 'zh' # for pickling
|
lex_attr_getters[LANG] = lambda text: 'zh' # for pickling
|
||||||
use_jieba = True
|
use_jieba = True
|
||||||
|
tokenizer_exceptions = update_exc(BASE_EXCEPTIONS, TOKENIZER_EXCEPTIONS)
|
||||||
|
tag_map = TAG_MAP
|
||||||
|
stop_words = STOP_WORDS
|
||||||
|
|
||||||
|
|
||||||
class Chinese(Language):
|
class Chinese(Language):
|
||||||
|
|
1901
spacy/lang/zh/stop_words.py
Normal file
1901
spacy/lang/zh/stop_words.py
Normal file
File diff suppressed because it is too large
Load Diff
24
spacy/lang/zh/tag_map.py
Normal file
24
spacy/lang/zh/tag_map.py
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
# encoding: utf8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from ...symbols import *
|
||||||
|
|
||||||
|
|
||||||
|
TAG_MAP = {
|
||||||
|
"ADV": {POS: ADV},
|
||||||
|
"NOUN": {POS: NOUN},
|
||||||
|
"ADP": {POS: ADP},
|
||||||
|
"PRON": {POS: PRON},
|
||||||
|
"SCONJ": {POS: SCONJ},
|
||||||
|
"PROPN": {POS: PROPN},
|
||||||
|
"DET": {POS: DET},
|
||||||
|
"SYM": {POS: SYM},
|
||||||
|
"INTJ": {POS: INTJ},
|
||||||
|
"PUNCT": {POS: PUNCT},
|
||||||
|
"NUM": {POS: NUM},
|
||||||
|
"AUX": {POS: AUX},
|
||||||
|
"X": {POS: X},
|
||||||
|
"CONJ": {POS: CONJ},
|
||||||
|
"ADJ": {POS: ADJ},
|
||||||
|
"VERB": {POS: VERB}
|
||||||
|
}
|
45
spacy/lang/zh/tokenizer_exceptions.py
Normal file
45
spacy/lang/zh/tokenizer_exceptions.py
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
# encoding: utf8
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from ...symbols import *
|
||||||
|
|
||||||
|
|
||||||
|
TOKENIZER_EXCEPTIONS = {
|
||||||
|
"Jan.": [
|
||||||
|
{ORTH: "Jan.", LEMMA: "January"}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# exceptions mapped to a single token containing only ORTH property
|
||||||
|
# example: {"string": [{ORTH: "string"}]}
|
||||||
|
# converted using strings_to_exc() util
|
||||||
|
|
||||||
|
ORTH_ONLY = [
|
||||||
|
"a.",
|
||||||
|
"b.",
|
||||||
|
"c.",
|
||||||
|
"d.",
|
||||||
|
"e.",
|
||||||
|
"f.",
|
||||||
|
"g.",
|
||||||
|
"h.",
|
||||||
|
"i.",
|
||||||
|
"j.",
|
||||||
|
"k.",
|
||||||
|
"l.",
|
||||||
|
"m.",
|
||||||
|
"n.",
|
||||||
|
"o.",
|
||||||
|
"p.",
|
||||||
|
"q.",
|
||||||
|
"r.",
|
||||||
|
"s.",
|
||||||
|
"t.",
|
||||||
|
"u.",
|
||||||
|
"v.",
|
||||||
|
"w.",
|
||||||
|
"x.",
|
||||||
|
"y.",
|
||||||
|
"z."
|
||||||
|
]
|
|
@ -96,49 +96,40 @@ def he_tokenizer():
|
||||||
def nb_tokenizer():
|
def nb_tokenizer():
|
||||||
return get_lang_class('nb').Defaults.create_tokenizer()
|
return get_lang_class('nb').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def da_tokenizer():
|
def da_tokenizer():
|
||||||
return get_lang_class('da').Defaults.create_tokenizer()
|
return get_lang_class('da').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def ja_tokenizer():
|
def ja_tokenizer():
|
||||||
mecab = pytest.importorskip("MeCab")
|
mecab = pytest.importorskip("MeCab")
|
||||||
return get_lang_class('ja').Defaults.create_tokenizer()
|
return get_lang_class('ja').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def th_tokenizer():
|
def th_tokenizer():
|
||||||
pythainlp = pytest.importorskip("pythainlp")
|
pythainlp = pytest.importorskip("pythainlp")
|
||||||
return get_lang_class('th').Defaults.create_tokenizer()
|
return get_lang_class('th').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def tr_tokenizer():
|
def tr_tokenizer():
|
||||||
return get_lang_class('tr').Defaults.create_tokenizer()
|
return get_lang_class('tr').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def tt_tokenizer():
|
def tt_tokenizer():
|
||||||
return get_lang_class('tt').Defaults.create_tokenizer()
|
return get_lang_class('tt').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def el_tokenizer():
|
def el_tokenizer():
|
||||||
return get_lang_class('el').Defaults.create_tokenizer()
|
return get_lang_class('el').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def ar_tokenizer():
|
def ar_tokenizer():
|
||||||
return get_lang_class('ar').Defaults.create_tokenizer()
|
return get_lang_class('ar').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def ur_tokenizer():
|
def ur_tokenizer():
|
||||||
return get_lang_class('ur').Defaults.create_tokenizer()
|
return get_lang_class('ur').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture(scope='session')
|
@pytest.fixture(scope='session')
|
||||||
def ru_tokenizer():
|
def ru_tokenizer():
|
||||||
pymorphy = pytest.importorskip('pymorphy2')
|
pymorphy = pytest.importorskip('pymorphy2')
|
||||||
|
|
|
@ -150,3 +150,31 @@ def test_span_as_doc(doc):
|
||||||
span = doc[4:10]
|
span = doc[4:10]
|
||||||
span_doc = span.as_doc()
|
span_doc = span.as_doc()
|
||||||
assert span.text == span_doc.text.strip()
|
assert span.text == span_doc.text.strip()
|
||||||
|
|
||||||
|
def test_span_ents_property(doc):
|
||||||
|
"""Test span.ents for the """
|
||||||
|
doc.ents = [
|
||||||
|
(doc.vocab.strings['PRODUCT'], 0, 1),
|
||||||
|
(doc.vocab.strings['PRODUCT'], 7, 8),
|
||||||
|
(doc.vocab.strings['PRODUCT'], 11, 14)
|
||||||
|
]
|
||||||
|
assert len(list(doc.ents)) == 3
|
||||||
|
sentences = list(doc.sents)
|
||||||
|
assert len(sentences) == 3
|
||||||
|
assert len(sentences[0].ents) == 1
|
||||||
|
# First sentence, also tests start of sentence
|
||||||
|
assert sentences[0].ents[0].text == "This"
|
||||||
|
assert sentences[0].ents[0].label_ == "PRODUCT"
|
||||||
|
assert sentences[0].ents[0].start == 0
|
||||||
|
assert sentences[0].ents[0].end == 1
|
||||||
|
# Second sentence
|
||||||
|
assert len(sentences[1].ents) == 1
|
||||||
|
assert sentences[1].ents[0].text == "another"
|
||||||
|
assert sentences[1].ents[0].label_ == "PRODUCT"
|
||||||
|
assert sentences[1].ents[0].start == 7
|
||||||
|
assert sentences[1].ents[0].end == 8
|
||||||
|
# Third sentence ents, Also tests end of sentence
|
||||||
|
assert sentences[2].ents[0].text == "a third ."
|
||||||
|
assert sentences[2].ents[0].label_ == "PRODUCT"
|
||||||
|
assert sentences[2].ents[0].start == 11
|
||||||
|
assert sentences[2].ents[0].end == 14
|
||||||
|
|
|
@ -2,6 +2,11 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
|
from .... import util
|
||||||
|
|
||||||
|
@pytest.fixture(scope='module')
|
||||||
|
def fr_tokenizer():
|
||||||
|
return util.get_lang_class('fr').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
@pytest.mark.parametrize('text', [
|
@pytest.mark.parametrize('text', [
|
||||||
|
|
|
@ -1,5 +1,13 @@
|
||||||
# coding: utf8
|
# coding: utf8
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from .... import util
|
||||||
|
|
||||||
|
@pytest.fixture(scope='module')
|
||||||
|
def fr_tokenizer():
|
||||||
|
return util.get_lang_class('fr').Defaults.create_tokenizer()
|
||||||
|
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
from spacy.lang.fr.lex_attrs import like_num
|
from spacy.lang.fr.lex_attrs import like_num
|
||||||
|
|
|
@ -6,7 +6,8 @@ import pytest
|
||||||
|
|
||||||
SV_TOKEN_EXCEPTION_TESTS = [
|
SV_TOKEN_EXCEPTION_TESTS = [
|
||||||
('Smörsåsen används bl.a. till fisk', ['Smörsåsen', 'används', 'bl.a.', 'till', 'fisk']),
|
('Smörsåsen används bl.a. till fisk', ['Smörsåsen', 'används', 'bl.a.', 'till', 'fisk']),
|
||||||
('Jag kommer först kl. 13 p.g.a. diverse förseningar', ['Jag', 'kommer', 'först', 'kl.', '13', 'p.g.a.', 'diverse', 'förseningar'])
|
('Jag kommer först kl. 13 p.g.a. diverse förseningar', ['Jag', 'kommer', 'först', 'kl.', '13', 'p.g.a.', 'diverse', 'förseningar']),
|
||||||
|
('Anders I. tycker om ord med i i.', ["Anders", "I.", "tycker", "om", "ord", "med", "i", "i", "."])
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|
11
spacy/tests/regression/test_issue2626.py
Normal file
11
spacy/tests/regression/test_issue2626.py
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
import spacy
|
||||||
|
|
||||||
|
def test_issue2626():
|
||||||
|
'''Check that this sentence doesn't cause an infinite loop in the tokenizer.'''
|
||||||
|
nlp = spacy.blank('en')
|
||||||
|
text = """
|
||||||
|
ABLEItemColumn IAcceptance Limits of ErrorIn-Service Limits of ErrorColumn IIColumn IIIColumn IVColumn VComputed VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeCubic FeetCubic FeetCubic FeetCubic FeetCubic Feet1Up to 10.0100.0050.0100.005220.0200.0100.0200.010350.0360.0180.0360.0184100.0500.0250.0500.0255Over 100.5% of computed volume0.25% of computed volume0.5% of computed volume0.25% of computed volume TABLE ItemColumn IAcceptance Limits of ErrorIn-Service Limits of ErrorColumn IIColumn IIIColumn IVColumn VComputed VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeCubic FeetCubic FeetCubic FeetCubic FeetCubic Feet1Up to 10.0100.0050.0100.005220.0200.0100.0200.010350.0360.0180.0360.0184100.0500.0250.0500.0255Over 100.5% of computed volume0.25% of computed volume0.5% of computed volume0.25% of computed volume ItemColumn IAcceptance Limits of ErrorIn-Service Limits of ErrorColumn IIColumn IIIColumn IVColumn VComputed VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeUnder Registration of\xa0VolumeOver Registration of\xa0VolumeCubic FeetCubic FeetCubic FeetCubic FeetCubic Feet1Up to 10.0100.0050.0100.005220.0200.0100.0200.010350.0360.0180.0360.0184100.0500.0250.0500.0255Over 100.5% of computed volume0.25% of computed volume0.5% of computed volume0.25% of computed volume
|
||||||
|
"""
|
||||||
|
doc = nlp.make_doc(text)
|
||||||
|
|
0
spacy/tests/zh/__init__.py
Normal file
0
spacy/tests/zh/__init__.py
Normal file
|
@ -324,6 +324,15 @@ cdef class Span:
|
||||||
break
|
break
|
||||||
return self.doc[start:end]
|
return self.doc[start:end]
|
||||||
|
|
||||||
|
property ents:
|
||||||
|
"""RETURNS (list): A list of tokens that belong to the current span."""
|
||||||
|
def __get__(self):
|
||||||
|
ents = []
|
||||||
|
for ent in self.doc.ents:
|
||||||
|
if ent.start >= self.start and ent.end <= self.end:
|
||||||
|
ents.append(ent)
|
||||||
|
return ents
|
||||||
|
|
||||||
property has_vector:
|
property has_vector:
|
||||||
"""RETURNS (bool): Whether a word vector is associated with the object.
|
"""RETURNS (bool): Whether a word vector is associated with the object.
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
|
|
||||||
- MODEL_COUNT = Object.keys(MODELS).map(m => Object.keys(MODELS[m]).length).reduce((a, b) => a + b)
|
- MODEL_COUNT = Object.keys(MODELS).map(m => Object.keys(MODELS[m]).length).reduce((a, b) => a + b)
|
||||||
- MODEL_LANG_COUNT = Object.keys(MODELS).length
|
- MODEL_LANG_COUNT = Object.keys(MODELS).length
|
||||||
- LANG_COUNT = Object.keys(LANGUAGES).length
|
- LANG_COUNT = Object.keys(LANGUAGES).length - 1
|
||||||
|
|
||||||
- MODEL_META = public.models._data.MODEL_META
|
- MODEL_META = public.models._data.MODEL_META
|
||||||
- MODEL_LICENSES = public.models._data.MODEL_LICENSES
|
- MODEL_LICENSES = public.models._data.MODEL_LICENSES
|
||||||
|
|
|
@ -107,4 +107,3 @@ for id in CURRENT_MODELS
|
||||||
print(doc.text)
|
print(doc.text)
|
||||||
for token in doc:
|
for token in doc:
|
||||||
print(token.text, token.pos_, token.dep_)
|
print(token.text, token.pos_, token.dep_)
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ p
|
||||||
+table(["Name", "Type", "Description", "Default"])
|
+table(["Name", "Type", "Description", "Default"])
|
||||||
+row
|
+row
|
||||||
+cell #[code docs]
|
+cell #[code docs]
|
||||||
+cell list or #[code Doc]
|
+cell list, #[code Doc], #[code Span]
|
||||||
+cell Document(s) to visualize.
|
+cell Document(s) to visualize.
|
||||||
+cell
|
+cell
|
||||||
|
|
||||||
|
@ -84,7 +84,7 @@ p Render a dependency parse tree or named entity visualization.
|
||||||
+table(["Name", "Type", "Description", "Default"])
|
+table(["Name", "Type", "Description", "Default"])
|
||||||
+row
|
+row
|
||||||
+cell #[code docs]
|
+cell #[code docs]
|
||||||
+cell list or #[code Doc]
|
+cell list, #[code Doc], #[code Span]
|
||||||
+cell Document(s) to visualize.
|
+cell Document(s) to visualize.
|
||||||
+cell
|
+cell
|
||||||
|
|
||||||
|
@ -157,6 +157,12 @@ p
|
||||||
| as it prevents long arcs to attach punctuation.
|
| as it prevents long arcs to attach punctuation.
|
||||||
+cell #[code True]
|
+cell #[code True]
|
||||||
|
|
||||||
|
+row
|
||||||
|
+cell #[code collapse_phrases]
|
||||||
|
+cell bool
|
||||||
|
+cell Merge noun phrases into one token.
|
||||||
|
+cell #[code False]
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code compact]
|
+cell #[code compact]
|
||||||
+cell bool
|
+cell bool
|
||||||
|
|
|
@ -136,6 +136,12 @@ p
|
||||||
+cell flag
|
+cell flag
|
||||||
+cell Print information as Markdown.
|
+cell Print information as Markdown.
|
||||||
|
|
||||||
|
+row
|
||||||
|
+cell #[code --silent], #[code -s]
|
||||||
|
+tag-new("2.0.12")
|
||||||
|
+cell flag
|
||||||
|
+cell Don't print anything, just return the values.
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code --help], #[code -h]
|
+cell #[code --help], #[code -h]
|
||||||
+cell flag
|
+cell flag
|
||||||
|
@ -254,7 +260,7 @@ p
|
||||||
+code(false, "bash", "$", false, false, true).
|
+code(false, "bash", "$", false, false, true).
|
||||||
python -m spacy train [lang] [output_dir] [train_data] [dev_data] [--n-iter]
|
python -m spacy train [lang] [output_dir] [train_data] [dev_data] [--n-iter]
|
||||||
[--n-sents] [--use-gpu] [--meta-path] [--vectors] [--no-tagger] [--no-parser]
|
[--n-sents] [--use-gpu] [--meta-path] [--vectors] [--no-tagger] [--no-parser]
|
||||||
[--no-entities] [--gold-preproc]
|
[--no-entities] [--gold-preproc] [--verbose]
|
||||||
|
|
||||||
+table(["Argument", "Type", "Description"])
|
+table(["Argument", "Type", "Description"])
|
||||||
+row
|
+row
|
||||||
|
@ -338,6 +344,11 @@ p
|
||||||
+cell flag
|
+cell flag
|
||||||
+cell Show help message and available arguments.
|
+cell Show help message and available arguments.
|
||||||
|
|
||||||
|
+row
|
||||||
|
+cell #[code --verbose]
|
||||||
|
+cell flag
|
||||||
|
+cell Show more detail message during training.
|
||||||
|
|
||||||
+row("foot")
|
+row("foot")
|
||||||
+cell creates
|
+cell creates
|
||||||
+cell model, pickle
|
+cell model, pickle
|
||||||
|
|
|
@ -202,8 +202,8 @@ p
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
from spacy.tokens import Doc
|
from spacy.tokens import Doc
|
||||||
Doc.set_extension('is_city', default=False)
|
Doc.set_extension('has_city', default=False)
|
||||||
extension = Doc.get_extension('is_city')
|
extension = Doc.get_extension('has_city')
|
||||||
assert extension == (False, None, None, None)
|
assert extension == (False, None, None, None)
|
||||||
|
|
||||||
+table(["Name", "Type", "Description"])
|
+table(["Name", "Type", "Description"])
|
||||||
|
@ -227,8 +227,8 @@ p Check whether an extension has been registered on the #[code Doc] class.
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
from spacy.tokens import Doc
|
from spacy.tokens import Doc
|
||||||
Doc.set_extension('is_city', default=False)
|
Doc.set_extension('has_city', default=False)
|
||||||
assert Doc.has_extension('is_city')
|
assert Doc.has_extension('has_city')
|
||||||
|
|
||||||
+table(["Name", "Type", "Description"])
|
+table(["Name", "Type", "Description"])
|
||||||
+row
|
+row
|
||||||
|
@ -241,6 +241,31 @@ p Check whether an extension has been registered on the #[code Doc] class.
|
||||||
+cell bool
|
+cell bool
|
||||||
+cell Whether the extension has been registered.
|
+cell Whether the extension has been registered.
|
||||||
|
|
||||||
|
+h(2, "remove_extension") Doc.remove_extension
|
||||||
|
+tag classmethod
|
||||||
|
+tag-new("2.0.12")
|
||||||
|
|
||||||
|
p Remove a previously registered extension.
|
||||||
|
|
||||||
|
+aside-code("Example").
|
||||||
|
from spacy.tokens import Doc
|
||||||
|
Doc.set_extension('has_city', default=False)
|
||||||
|
removed = Doc.remove_extension('has_city')
|
||||||
|
assert not Doc.has_extension('has_city')
|
||||||
|
|
||||||
|
+table(["Name", "Type", "Description"])
|
||||||
|
+row
|
||||||
|
+cell #[code name]
|
||||||
|
+cell unicode
|
||||||
|
+cell Name of the extension.
|
||||||
|
|
||||||
|
+row("foot")
|
||||||
|
+cell returns
|
||||||
|
+cell tuple
|
||||||
|
+cell
|
||||||
|
| A #[code.u-break (default, method, getter, setter)] tuple of the
|
||||||
|
| removed extension.
|
||||||
|
|
||||||
+h(2, "char_span") Doc.char_span
|
+h(2, "char_span") Doc.char_span
|
||||||
+tag method
|
+tag method
|
||||||
+tag-new(2)
|
+tag-new(2)
|
||||||
|
@ -263,7 +288,7 @@ p
|
||||||
+row
|
+row
|
||||||
+cell #[code end]
|
+cell #[code end]
|
||||||
+cell int
|
+cell int
|
||||||
+cell The index of the first character after the span.
|
+cell The index of the last character after the span.
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code label]
|
+cell #[code label]
|
||||||
|
@ -761,6 +786,13 @@ p
|
||||||
+cell bool
|
+cell bool
|
||||||
+cell A flag indicating that the document has been syntactically parsed.
|
+cell A flag indicating that the document has been syntactically parsed.
|
||||||
|
|
||||||
|
+row
|
||||||
|
+cell #[code is_sentenced]
|
||||||
|
+cell bool
|
||||||
|
+cell
|
||||||
|
| A flag indicating that sentence boundaries have been applied to
|
||||||
|
| the document.
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code sentiment]
|
+cell #[code sentiment]
|
||||||
+cell float
|
+cell float
|
||||||
|
|
|
@ -513,11 +513,19 @@ p
|
||||||
p
|
p
|
||||||
| Loads state from a directory. Modifies the object in place and returns
|
| Loads state from a directory. Modifies the object in place and returns
|
||||||
| it. If the saved #[code Language] object contains a model, the
|
| it. If the saved #[code Language] object contains a model, the
|
||||||
| #[strong model will be loaded].
|
| model will be loaded. Note that this method is commonly used via the
|
||||||
|
| subclasses like #[code English] or #[code German] to make
|
||||||
|
| language-specific functionality like the
|
||||||
|
| #[+a("/usage/adding-languages#lex-attrs") lexical attribute getters]
|
||||||
|
| available to the loaded object.
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
from spacy.language import Language
|
from spacy.language import Language
|
||||||
nlp = Language().from_disk('/path/to/models')
|
nlp = Language().from_disk('/path/to/model')
|
||||||
|
|
||||||
|
# using language-specific subclass
|
||||||
|
from spacy.lang.en import English
|
||||||
|
nlp = English().from_disk('/path/to/en_model')
|
||||||
|
|
||||||
+table(["Name", "Type", "Description"])
|
+table(["Name", "Type", "Description"])
|
||||||
+row
|
+row
|
||||||
|
@ -575,10 +583,15 @@ p Serialize the current state to a binary string.
|
||||||
+h(2, "from_bytes") Language.from_bytes
|
+h(2, "from_bytes") Language.from_bytes
|
||||||
+tag method
|
+tag method
|
||||||
|
|
||||||
p Load state from a binary string.
|
p
|
||||||
|
| Load state from a binary string. Note that this method is commonly used
|
||||||
|
| via the subclasses like #[code English] or #[code German] to make
|
||||||
|
| language-specific functionality like the
|
||||||
|
| #[+a("/usage/adding-languages#lex-attrs") lexical attribute getters]
|
||||||
|
| available to the loaded object.
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
fron spacy.lang.en import English
|
from spacy.lang.en import English
|
||||||
nlp_bytes = nlp.to_bytes()
|
nlp_bytes = nlp.to_bytes()
|
||||||
nlp2 = English()
|
nlp2 = English()
|
||||||
nlp2.from_bytes(nlp_bytes)
|
nlp2.from_bytes(nlp_bytes)
|
||||||
|
|
|
@ -219,6 +219,31 @@ p Check whether an extension has been registered on the #[code Span] class.
|
||||||
+cell bool
|
+cell bool
|
||||||
+cell Whether the extension has been registered.
|
+cell Whether the extension has been registered.
|
||||||
|
|
||||||
|
+h(2, "remove_extension") Span.remove_extension
|
||||||
|
+tag classmethod
|
||||||
|
+tag-new("2.0.12")
|
||||||
|
|
||||||
|
p Remove a previously registered extension.
|
||||||
|
|
||||||
|
+aside-code("Example").
|
||||||
|
from spacy.tokens import Span
|
||||||
|
Span.set_extension('is_city', default=False)
|
||||||
|
removed = Span.remove_extension('is_city')
|
||||||
|
assert not Span.has_extension('is_city')
|
||||||
|
|
||||||
|
+table(["Name", "Type", "Description"])
|
||||||
|
+row
|
||||||
|
+cell #[code name]
|
||||||
|
+cell unicode
|
||||||
|
+cell Name of the extension.
|
||||||
|
|
||||||
|
+row("foot")
|
||||||
|
+cell returns
|
||||||
|
+cell tuple
|
||||||
|
+cell
|
||||||
|
| A #[code.u-break (default, method, getter, setter)] tuple of the
|
||||||
|
| removed extension.
|
||||||
|
|
||||||
+h(2, "similarity") Span.similarity
|
+h(2, "similarity") Span.similarity
|
||||||
+tag method
|
+tag method
|
||||||
+tag-model("vectors")
|
+tag-model("vectors")
|
||||||
|
|
|
@ -154,6 +154,31 @@ p Check whether an extension has been registered on the #[code Token] class.
|
||||||
+cell bool
|
+cell bool
|
||||||
+cell Whether the extension has been registered.
|
+cell Whether the extension has been registered.
|
||||||
|
|
||||||
|
+h(2, "remove_extension") Token.remove_extension
|
||||||
|
+tag classmethod
|
||||||
|
+tag-new("2.0.11")
|
||||||
|
|
||||||
|
p Remove a previously registered extension.
|
||||||
|
|
||||||
|
+aside-code("Example").
|
||||||
|
from spacy.tokens import Token
|
||||||
|
Token.set_extension('is_fruit', default=False)
|
||||||
|
removed = Token.remove_extension('is_fruit')
|
||||||
|
assert not Token.has_extension('is_fruit')
|
||||||
|
|
||||||
|
+table(["Name", "Type", "Description"])
|
||||||
|
+row
|
||||||
|
+cell #[code name]
|
||||||
|
+cell unicode
|
||||||
|
+cell Name of the extension.
|
||||||
|
|
||||||
|
+row("foot")
|
||||||
|
+cell returns
|
||||||
|
+cell tuple
|
||||||
|
+cell
|
||||||
|
| A #[code.u-break (default, method, getter, setter)] tuple of the
|
||||||
|
| removed extension.
|
||||||
|
|
||||||
+h(2, "check_flag") Token.check_flag
|
+h(2, "check_flag") Token.check_flag
|
||||||
+tag method
|
+tag method
|
||||||
|
|
||||||
|
@ -380,7 +405,7 @@ p
|
||||||
+tag property
|
+tag property
|
||||||
+tag-model("parse")
|
+tag-model("parse")
|
||||||
|
|
||||||
p A sequence of all the token's syntactic descendents.
|
p A sequence of all the token's syntactic descendants.
|
||||||
|
|
||||||
+aside-code("Example").
|
+aside-code("Example").
|
||||||
doc = nlp(u'Give it back! He pleaded.')
|
doc = nlp(u'Give it back! He pleaded.')
|
||||||
|
@ -484,6 +509,17 @@ p The L2 norm of the token's vector representation.
|
||||||
+h(2, "attributes") Attributes
|
+h(2, "attributes") Attributes
|
||||||
|
|
||||||
+table(["Name", "Type", "Description"])
|
+table(["Name", "Type", "Description"])
|
||||||
|
+row
|
||||||
|
+cell #[code doc]
|
||||||
|
+cell #[code Doc]
|
||||||
|
+cell The parent document.
|
||||||
|
|
||||||
|
+row
|
||||||
|
+cell #[code sent]
|
||||||
|
+tag-new("2.0.12")
|
||||||
|
+cell #[code Span]
|
||||||
|
+cell The sentence span that this token is a part of.
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code text]
|
+cell #[code text]
|
||||||
+cell unicode
|
+cell unicode
|
||||||
|
@ -534,7 +570,7 @@ p The L2 norm of the token's vector representation.
|
||||||
+row
|
+row
|
||||||
+cell #[code right_edge]
|
+cell #[code right_edge]
|
||||||
+cell #[code Token]
|
+cell #[code Token]
|
||||||
+cell The rightmost token of this token's syntactic descendents.
|
+cell The rightmost token of this token's syntactic descendants.
|
||||||
|
|
||||||
+row
|
+row
|
||||||
+cell #[code i]
|
+cell #[code i]
|
||||||
|
|
|
@ -95,7 +95,7 @@
|
||||||
|
|
||||||
"EXAMPLE_SENT_LANGS": [
|
"EXAMPLE_SENT_LANGS": [
|
||||||
"da", "de", "en", "es", "fa", "fr", "he", "hi", "hu", "id", "it", "ja",
|
"da", "de", "en", "es", "fa", "fr", "he", "hi", "hu", "id", "it", "ja",
|
||||||
"nb", "nl", "pl", "pt", "ru", "sv", "tr", "zh"
|
"nb", "pl", "pt", "ru", "sv", "tr", "zh"
|
||||||
],
|
],
|
||||||
|
|
||||||
"LANGUAGES": {
|
"LANGUAGES": {
|
||||||
|
|
|
@ -251,27 +251,29 @@
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"id": "spacy-lefff",
|
"id": "spacy-lefff",
|
||||||
"slogan": "French lemmatization with Lefff",
|
"slogan": "POS and French lemmatization with Lefff",
|
||||||
"description": "spacy v2.0 extension and pipeline component for adding a French lemmatizer based on [Lefff](https://hal.inria.fr/inria-00521242/).",
|
"description": "spacy v2.0 extension and pipeline component for adding a French POS and lemmatizer based on [Lefff](https://hal.inria.fr/inria-00521242/).",
|
||||||
"github": "sammous/spacy-lefff",
|
"github": "sammous/spacy-lefff",
|
||||||
"pip": "spacy-lefff",
|
"pip": "spacy-lefff",
|
||||||
"code_example": [
|
"code_example": [
|
||||||
"import spacy",
|
"import spacy",
|
||||||
"from spacy_lefff import LefffLemmatizer",
|
"from spacy_lefff import LefffLemmatizer, POSTagger",
|
||||||
"",
|
"",
|
||||||
"nlp = spacy.load('fr')",
|
"nlp = spacy.load('fr')",
|
||||||
"french_lemmatizer = LefffLemmatizer()",
|
"pos = POSTagger()",
|
||||||
"nlp.add_pipe(french_lemmatizer, name='lefff', after='parser')",
|
"french_lemmatizer = LefffLemmatizer(after_melt=True)",
|
||||||
|
"nlp.add_pipe(pos, name='pos', after='parser')",
|
||||||
|
"nlp.add_pipe(french_lemmatizer, name='lefff', after='pos')",
|
||||||
"doc = nlp(u\"Paris est une ville très chère.\")",
|
"doc = nlp(u\"Paris est une ville très chère.\")",
|
||||||
"for d in doc:",
|
"for d in doc:",
|
||||||
" print(d.text, d.pos_, d._.lefff_lemma, d.tag_)"
|
" print(d.text, d.pos_, d._.melt_tagger, d._.lefff_lemma, d.tag_, d.lemma_)"
|
||||||
],
|
],
|
||||||
"author": "Sami Moustachir",
|
"author": "Sami Moustachir",
|
||||||
"author_links": {
|
"author_links": {
|
||||||
"github": "sammous"
|
"github": "sammous"
|
||||||
},
|
},
|
||||||
"category": ["pipeline"],
|
"category": ["pipeline"],
|
||||||
"tags": ["lemmatizer", "french"]
|
"tags": ["pos", "lemmatizer", "french"]
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"id": "lemmy",
|
"id": "lemmy",
|
||||||
|
@ -943,17 +945,19 @@
|
||||||
{
|
{
|
||||||
"id": "excelcy",
|
"id": "excelcy",
|
||||||
"title": "ExcelCy",
|
"title": "ExcelCy",
|
||||||
"slogan": "Excel Integration with SpaCy. Includes, Entity training, Entity matcher pipe.",
|
"slogan": "Excel Integration with spaCy. Training NER using XLSX from PDF, DOCX, PPT, PNG or JPG.",
|
||||||
"description": "ExcelCy is a SpaCy toolkit to help improve the data training experiences. It provides easy annotation using Excel file format. It has helper to pre-train entity annotation with phrase and regex matcher pipe.",
|
"description": "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.",
|
||||||
"url": "https://github.com/kororo/excelcy",
|
"url": "https://github.com/kororo/excelcy",
|
||||||
"github": "kororo/excelcy",
|
"github": "kororo/excelcy",
|
||||||
"pip": "excelcy",
|
"pip": "excelcy",
|
||||||
"code_example": [
|
"code_example": [
|
||||||
"from excelcy import ExcelCy",
|
"from excelcy import ExcelCy",
|
||||||
"",
|
"# collect sentences, annotate Entities and train NER using spaCy",
|
||||||
"excelcy = ExcelCy()",
|
"excelcy = ExcelCy.execute(file_path='https://github.com/kororo/excelcy/raw/master/tests/data/test_data_01.xlsx')",
|
||||||
"# download data from here, https://github.com/kororo/excelcy/tree/master/excelcy/tests/data/test_data_28.xlsx",
|
"# use the nlp object as per spaCy API",
|
||||||
"excelcy.train(data_path='test_data_28.xlsx')"
|
"doc = excelcy.nlp('Google rebrands its business apps')",
|
||||||
|
"# or save it for faster bootstrap for application",
|
||||||
|
"excelcy.nlp.to_disk('/model')"
|
||||||
],
|
],
|
||||||
"author": "Robertus Johansyah",
|
"author": "Robertus Johansyah",
|
||||||
"author_links": {
|
"author_links": {
|
||||||
|
@ -961,6 +965,45 @@
|
||||||
},
|
},
|
||||||
"category": ["training"],
|
"category": ["training"],
|
||||||
"tags": ["excel"]
|
"tags": ["excel"]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "spacy-graphql",
|
||||||
|
"title": "spacy-graphql",
|
||||||
|
"slogan": "Query spaCy's linguistic annotations using GraphQL",
|
||||||
|
"github": "ines/spacy-graphql",
|
||||||
|
"description": "A very simple and experimental app that lets you query spaCy's linguistic annotations using [GraphQL](https://graphql.org/). The API currently supports most token attributes, named entities, sentences and text categories (if available as `doc.cats`, i.e. if you added a text classifier to a model). The `meta` field will return the model meta data. Models are only loaded once and kept in memory.",
|
||||||
|
"url": "https://explosion.ai/demos/spacy-graphql",
|
||||||
|
"category": ["apis"],
|
||||||
|
"tags": ["graphql"],
|
||||||
|
"thumb": "https://i.imgur.com/xC7zpTO.png",
|
||||||
|
"code_example": [
|
||||||
|
"{",
|
||||||
|
" nlp(text: \"Zuckerberg is the CEO of Facebook.\", model: \"en_core_web_sm\") {",
|
||||||
|
" meta {",
|
||||||
|
" lang",
|
||||||
|
" description",
|
||||||
|
" }",
|
||||||
|
" doc {",
|
||||||
|
" text",
|
||||||
|
" tokens {",
|
||||||
|
" text",
|
||||||
|
" pos_",
|
||||||
|
" }",
|
||||||
|
" ents {",
|
||||||
|
" text",
|
||||||
|
" label_",
|
||||||
|
" }",
|
||||||
|
" }",
|
||||||
|
" }",
|
||||||
|
"}"
|
||||||
|
],
|
||||||
|
"code_language": "json",
|
||||||
|
"author": "Ines Montani",
|
||||||
|
"author_links": {
|
||||||
|
"twitter": "_inesmontani",
|
||||||
|
"github": "ines",
|
||||||
|
"website": "https://ines.io"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"projectCats": {
|
"projectCats": {
|
||||||
|
@ -970,7 +1013,7 @@
|
||||||
},
|
},
|
||||||
"training": {
|
"training": {
|
||||||
"title": "Training",
|
"title": "Training",
|
||||||
"description": "Helpers and toolkits for trainig spaCy models"
|
"description": "Helpers and toolkits for training spaCy models"
|
||||||
},
|
},
|
||||||
"conversational": {
|
"conversational": {
|
||||||
"title": "Conversational",
|
"title": "Conversational",
|
||||||
|
|
|
@ -103,7 +103,7 @@
|
||||||
"menu": {
|
"menu": {
|
||||||
"How Pipelines Work": "pipelines",
|
"How Pipelines Work": "pipelines",
|
||||||
"Custom Components": "custom-components",
|
"Custom Components": "custom-components",
|
||||||
"Extension Attributes": "custom-components-extensions",
|
"Extension Attributes": "custom-components-attributes",
|
||||||
"Multi-Threading": "multithreading",
|
"Multi-Threading": "multithreading",
|
||||||
"Serialization": "serialization"
|
"Serialization": "serialization"
|
||||||
}
|
}
|
||||||
|
|
|
@ -103,8 +103,8 @@ p
|
||||||
+h(4, "ner-accuracy-ontonotes5") NER accuracy (OntoNotes 5, no pre-process)
|
+h(4, "ner-accuracy-ontonotes5") NER accuracy (OntoNotes 5, no pre-process)
|
||||||
|
|
||||||
p
|
p
|
||||||
| This is the evaluation we use to tune spaCy's parameters are decide which
|
| This is the evaluation we use to tune spaCy's parameters to decide which
|
||||||
| algorithms are better than others. It's reasonably close to actual usage,
|
| algorithms are better than the others. It's reasonably close to actual usage,
|
||||||
| because it requires the parses to be produced from raw text, without any
|
| because it requires the parses to be produced from raw text, without any
|
||||||
| pre-processing.
|
| pre-processing.
|
||||||
|
|
||||||
|
|
|
@ -129,8 +129,8 @@ p
|
||||||
substring = substring[split:]
|
substring = substring[split:]
|
||||||
elif find_suffix(substring) is not None:
|
elif find_suffix(substring) is not None:
|
||||||
split = find_suffix(substring)
|
split = find_suffix(substring)
|
||||||
suffixes.append(substring[split:])
|
suffixes.append(substring[-split:])
|
||||||
substring = substring[:split]
|
substring = substring[:-split]
|
||||||
elif find_infixes(substring):
|
elif find_infixes(substring):
|
||||||
infixes = find_infixes(substring)
|
infixes = find_infixes(substring)
|
||||||
offset = 0
|
offset = 0
|
||||||
|
|
|
@ -62,8 +62,8 @@ p
|
||||||
|
|
||||||
+code.
|
+code.
|
||||||
nlp_latin = spacy.load('/tmp/la_vectors_wiki_lg')
|
nlp_latin = spacy.load('/tmp/la_vectors_wiki_lg')
|
||||||
doc1 = nlp(u"Caecilius est in horto")
|
doc1 = nlp_latin(u"Caecilius est in horto")
|
||||||
doc2 = nlp(u"servus est in atrio")
|
doc2 = nlp_latin(u"servus est in atrio")
|
||||||
doc1.similarity(doc2)
|
doc1.similarity(doc2)
|
||||||
|
|
||||||
p
|
p
|
||||||
|
|
|
@ -60,3 +60,26 @@ p
|
||||||
displacy.serve(doc, style='dep', options=options)
|
displacy.serve(doc, style='dep', options=options)
|
||||||
|
|
||||||
+codepen("39c02c893a84794353de77a605d817fd", 360)
|
+codepen("39c02c893a84794353de77a605d817fd", 360)
|
||||||
|
|
||||||
|
+h(3, "dep-long-text") Visualizing long texts
|
||||||
|
+tag-new("2.0.12")
|
||||||
|
|
||||||
|
p
|
||||||
|
| Long texts can become difficult to read when displayed in one row, so
|
||||||
|
| it's often better to visualize them sentence-by-sentence instead. As of
|
||||||
|
| v2.0.12, #[code displacy] supports rendering both
|
||||||
|
| #[+api("doc") #[code Doc]] and #[+api("span") #[code Span]] objects, as
|
||||||
|
| well as lists of #[code Doc]s or #[code Span]s. Instead of passing the
|
||||||
|
| full #[code Doc] to #[code displacy.serve], you can also pass in a list
|
||||||
|
| of the #[code doc.sents]. This will create one visualization for each
|
||||||
|
| sentence.
|
||||||
|
|
||||||
|
+code.
|
||||||
|
import spacy
|
||||||
|
from spacy import displacy
|
||||||
|
|
||||||
|
nlp = spacy.load('en')
|
||||||
|
text = u"""In ancient Rome, some neighbors live in three adjacent houses. In the center is the house of Senex, who lives there with wife Domina, son Hero, and several slaves, including head slave Hysterium and the musical's main character Pseudolus. A slave belonging to Hero, Pseudolus wishes to buy, win, or steal his freedom. One of the neighboring houses is owned by Marcus Lycus, who is a buyer and seller of beautiful women; the other belongs to the ancient Erronius, who is abroad searching for his long-lost children (stolen in infancy by pirates). One day, Senex and Domina go on a trip and leave Pseudolus in charge of Hero. Hero confides in Pseudolus that he is in love with the lovely Philia, one of the courtesans in the House of Lycus (albeit still a virgin)."""
|
||||||
|
doc = nlp(text)
|
||||||
|
sentence_spans = list(doc.sents)
|
||||||
|
displacy.serve(sentence_spans, style='dep')
|
||||||
|
|
|
@ -12,8 +12,8 @@ include _spacy-101/_pipelines
|
||||||
+h(2, "custom-components") Creating custom pipeline components
|
+h(2, "custom-components") Creating custom pipeline components
|
||||||
include _processing-pipelines/_custom-components
|
include _processing-pipelines/_custom-components
|
||||||
|
|
||||||
+section("custom-components-extensions")
|
+section("custom-components-attributes")
|
||||||
+h(2, "custom-components-extensions") Extension attributes
|
+h(2, "custom-components-attributes") Extension attributes
|
||||||
+tag-new(2)
|
+tag-new(2)
|
||||||
include _processing-pipelines/_extensions
|
include _processing-pipelines/_extensions
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user