基于规则的命名实体识别

基于规则的命名实体识别(Rule-Based Named Entity Recognition, NER)是一种通过预定义的模式或规则来识别文本中特定实体的方法。这种方法通常使用正则表达式来匹配文本中的实体。下面是一个更完整的示例,展示了如何使用正则表达式来识别文本中的多个实体类型,包括人名、地点和日期

import re

def rule_based_entity_recognition(text):
    # 定义实体识别规则
    patterns = {
        'PERSON': r'(?:唐纳德|川普|特朗普)',
        'LOCATION': r'(?:白宫|华盛顿)',
        'DATE': r'\d{4}-\d{2}-\d{2}'  # YYYY-MM-DD 格式
    }

    # 存储识别结果
    entities = []

    # 遍历所有模式
    for entity_type, pattern in patterns.items():
         for match in re.finditer(pattern, text):
                 start, end = match.span()
                 entities.append({
                   'entity': match.group(),
                   'type': entity_type,
                   'start': start,
                   'end': end
            })

    return entities

# 测试文本
text = "特朗普于2020-01-01在白宫签署了重要文件。"

# 调用函数并打印结果
entities = rule_based_entity_recognition(text)

for entity in entities:
    print(f"Entity: {entity['entity']}, Type: {enti
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值