spaCy-Services 项目教程

spaCy-Services 项目教程

spacy-services💫 REST microservices for various spaCy-related tasks项目地址:https://gitcode.com/gh_mirrors/sp/spacy-services

1. 项目的目录结构及介绍

spacy-services/
├── displacy/
│   ├── app.py
│   ├── requirements.txt
│   └── README.md
├── matcher/
│   ├── app.py
│   ├── requirements.txt
│   └── README.md
├── sense2vec/
│   ├── app.py
│   ├── requirements.txt
│   └── README.md
├── .gitignore
├── LICENSE
├── README.md
└── setup.py

目录结构介绍

  • displacy/: 该目录包含用于服务 spaCy 的 displacy 功能的文件。

    • app.py: 启动文件。
    • requirements.txt: 依赖文件。
    • README.md: 说明文档。
  • matcher/: 该目录包含用于服务 spaCy 的 matcher 功能的文件。

    • app.py: 启动文件。
    • requirements.txt: 依赖文件。
    • README.md: 说明文档。
  • sense2vec/: 该目录包含用于服务 spaCy 的 sense2vec 功能的文件。

    • app.py: 启动文件。
    • requirements.txt: 依赖文件。
    • README.md: 说明文档。
  • .gitignore: Git 忽略文件。

  • LICENSE: 项目许可证。

  • README.md: 项目主说明文档。

  • setup.py: 项目安装文件。

2. 项目的启动文件介绍

displacy/app.py

from hug import route, hug
import spacy

nlp = spacy.load("en_core_web_sm")

@hug.get('/dep')
def dep(text: hug.types.text):
    doc = nlp(text)
    return {
        "text": [token.text for token in doc],
        "dep": [token.dep_ for token in doc],
        "head": [token.head.text for token in doc]
    }

@hug.get('/ent')
def ent(text: hug.types.text):
    doc = nlp(text)
    return {
        "text": [ent.text for ent in doc.ents],
        "label": [ent.label_ for ent in doc.ents]
    }

matcher/app.py

from hug import route, hug
import spacy

nlp = spacy.load("en_core_web_sm")

@hug.get('/match')
def match(text: hug.types.text, pattern: hug.types.text):
    doc = nlp(text)
    matcher = spacy.matcher.Matcher(nlp.vocab)
    matcher.add("Pattern", None, [pattern])
    matches = matcher(doc)
    return {
        "matches": matches,
        "tokens": [token.text for token in doc]
    }

sense2vec/app.py

from hug import route, hug
import spacy
from sense2vec import Sense2VecComponent

nlp = spacy.load("en_core_web_sm")
s2v = Sense2VecComponent(nlp.vocab)
nlp.add_pipe(s2v)

@hug.get('/sense2vec')
def sense2vec(text: hug.types.text):
    doc = nlp(text)
    return {
        "senses": [token._.s2v_key for token in doc]
    }

3. 项目的配置文件介绍

requirements.txt

每个服务目录下都有一个 requirements.txt 文件,用于指定该服务的依赖包。例如:

spacy==3.0.0
hug==2.6.1

setup.py

项目的根目录下有一个 setup.py 文件,用于项目的安装和分发。

from setuptools import setup, find_packages

setup(
    name="spacy-services",
    version="1.0",
    packages=find_packages(),
    install_requires=[
        "spacy==3.0.0",
        "hug==2.6

spacy-services💫 REST microservices for various spaCy-related tasks项目地址:https://gitcode.com/gh_mirrors/sp/spacy-services

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冯海莎Eliot

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值