news 2026/4/30 1:36:11

ML.NET实现人名、地名的提取

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ML.NET实现人名、地名的提取

ML.NET 可以通过文本分类或命名实体识别(NER)任务实现人名、地名的提取。以下是使用 ML.NET 实现该功能的核心思路和步骤:

核心原理

提取人名、地名属于命名实体识别(NER) 任务,本质是对文本中的每个词或字符进行分类(如“人名”“地名”“其他”)。ML.NET 可通过以下两种方式实现:

使用预训练模型:利用已训练好的 NER 模型直接进行预测(需配合支持实体识别的模型格式,如 ONNX)。
自定义训练:若有标注数据,可通过 ML.NET 的文本处理管道训练专属模型。

步骤示例(使用预训练模型)

1. 安装必要包

在项目中安装 ML.NET 核心包及 ONNX 模型支持包:

Install-Package Microsoft.ML
Install-Package Microsoft.ML.OnnxRuntime
Install-Package Microsoft.ML.OnnxTransformer


2. 准备预训练模型

获取支持中文命名实体识别的 ONNX 模型(如 bert-base-chinese-ner 转换的 ONNX 模型),放置在项目目录下。

3. 定义数据结构

// 输入数据:待处理的文本
public class TextInput
{
public string Text { get; set; }
}

// 输出数据:识别出的实体(包含实体类型和内容)
public class EntityOutput
{
public string EntityType { get; set; } // 如 "人名"、"地名"
public string EntityValue { get; set; } // 实体内容
}


4. 构建 ML 管道并预测

using Microsoft.ML;
using Microsoft.ML.Data;

class Program
{
static void Main()
{
// 初始化 ML 环境
var mlContext = new MLContext();

// 加载预训练的 ONNX 模型
var modelPath = "path/to/ner-model.onnx";

// 定义管道:加载模型并配置输入输出
var pipeline = mlContext.Transforms.ApplyOnnxModel(
outputColumnNames: new[] { "outputs" }, // 模型输出列名(需与模型匹配)
inputColumnNames: new[] { "inputs" }, // 模型输入列名(需与模型匹配)
modelFile: modelPath);

// 创建测试数据
var testData = mlContext.Data.LoadFromEnumerable(new[] {
new TextInput { Text = "张三在上海工作,李四来自北京。" }
});

// 加载模型并创建预测引擎
var model = pipeline.Fit(mlContext.Data.LoadFromEnumerable(new TextInput[0]));
var engine = mlContext.Model.CreatePredictionEngine<TextInput, EntityOutput>(model);

// 预测并提取实体
var result = engine.Predict(testData.First());
Console.WriteLine($"识别结果:{result.EntityType} - {result.EntityValue}");
// 预期输出类似:人名 - 张三;地名 - 上海;人名 - 李四;地名 - 北京
}
}


关键说明

- 模型选择:ML.NET 本身不自带预训练 NER 模型,需从第三方获取(如 Hugging Face 下载后转换为 ONNX 格式)。
- 自定义训练:若需针对特定场景优化,可准备标注数据(如用 [人名]张三[/人名]在[地名]上海[/地名] 格式标注),通过 TextFeaturizer 提取文本特征,配合 LightGbm 等算法训练分类模型。
- 局限性:相比 Python 的 NLP 库(如 spaCy、Hugging Face),ML.NET 在 NER 任务的生态和预训练模型丰富度上稍弱,适合已有 .NET 技术栈且需轻量集成的场景。

通过以上步骤,可基于 ML.NET 实现基础的人名、地名提取功能,实际应用中需根据模型类型调整输入输出配置。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 3:31:46

设计模式-适配器模式

引言 我们常常会遇到这样的情况&#xff1a;现有的类功能强大&#xff0c;但接口却与我们当前系统的需求不匹配。这就好比你有一把性能卓越的钥匙&#xff08;现有类&#xff09;&#xff0c;但锁眼&#xff08;系统接口需求&#xff09;却对不上。适配器模式就如同一位神奇的工…

作者头像 李华
网站建设 2026/4/29 19:53:00

Audacity音频处理指令由LobeChat智能生成

Audacity音频处理指令由LobeChat智能生成 在播客制作、语言教学或有声书编辑的日常工作中&#xff0c;一个常见的挑战是&#xff1a;如何高效地从长达数小时的录音中提取有效内容&#xff1f;传统方式往往依赖手动选区、反复试错和对软件功能的深度掌握——这不仅耗时费力&…

作者头像 李华
网站建设 2026/4/27 15:06:26

桌游规则说明:LobeChat清晰解释复杂机制

LobeChat&#xff1a;让复杂桌游规则变得清晰易懂 在智能家居设备日益复杂的今天&#xff0c;确保无线连接的稳定性已成为一大设计挑战。不过今天我们不聊硬件&#xff0c;而是把目光转向另一个“复杂系统”——桌面游戏。像《瘟疫危机》《卡坦岛》这类现代桌游&#xff0c;动辄…

作者头像 李华
网站建设 2026/4/25 14:09:31

无人机视觉锁定与目标跟踪技术深度解析(含完整代码)

前言 最近在做一个无人机自主跟踪的项目,踩了不少坑,也积累了一些经验。这篇文章把视觉锁定这块的核心技术点整理一下,从原理到代码实现都会涉及,希望对有类似需求的朋友有所帮助。 视觉锁定说白了就是让无人机"盯住"一个目标不放,听起来简单,实际做起来会遇…

作者头像 李华
网站建设 2026/4/28 22:33:04

图像人形凸显算法深度剖析:从人像分割到背景虚化的完整实现

前言 最近在做一个手机端的人像处理SDK,需要实现类似iPhone人像模式的效果。研究了一段时间,把核心技术点整理出来分享一下。 所谓"人形凸显",本质上就是把人从背景中"拎"出来,然后对背景做模糊或者其他处理,让人物主体更加突出。听起来简单,但要做…

作者头像 李华
网站建设 2026/4/24 17:07:50

LobeChat能否对接Tesla API?车辆状态查询与远程控制

LobeChat能否对接Tesla API&#xff1f;车辆状态查询与远程控制 在智能家居设备日益复杂的今天&#xff0c;人们早已不再满足于“点按操作”的交互方式。语音助手、AI管家、自动化场景——这些曾经属于科幻的设想&#xff0c;正逐步渗透进我们的日常生活。而当人工智能遇上智能…

作者头像 李华