AI智能搜索

通过网络资源可知有很多种开源方式实现智能搜索,其中hanlp在GitHub中响应居高

参考链接:

https://www.hanlp.com/

Java版:https://github.com/hankcs/HanLP
Python版:https://github.com/hankcs/pyhanlp

https://hanlp.hankcs.com/docs/api/restful_java.html

http://www.hankcs.com/nlp/hanlp.html

https://github.com/hankcs/HanLP/releases

浅谈拙见

Hanlp说明

想要调用hanlp,首先需要有相应jar包,具体下载地址已在参考链接中

其次,hanlp中包含一个配置文件hanlp.properties

如果想进行相似对比,文本推荐等需要hanlp语料库的支持,故还需语料库文件data-for-1.7.5.zip

由于现有需求,需要将jar包转换为dll文件在.net core 文件中引用

转换dll的方法可自行百度,但注意,.net framework 和.net core所需的dll并非是同一种,不然会报错。

稍后我将我转换的dll文件上传,链接后补

https://files.cnblogs.com/files/zwbsoft/hanlp-core-1.8.3.dll.zip?t=1668498093   记得去掉zip后缀

所有准备工作完成,将相当于jvm的文件IKVM.OpenJDK.Core.dll和将jar包解析出来的hanlp-core-1.8.3.dll同时引用到.net core 项目中

具体使用如下,相关使用参考官网文档

本人core程序,实践可行几种方式如下

  1. nlp分词

static void Main(string[] args)

{

Console.WriteLine("Hello World!");

try

{

java.lang.System.getProperties().setProperty("java.class.path", @"E:\\install\\hanlp");

Console.WriteLine(HanLP.segment("你好,欢迎在CSharp中调用HanLP的API! "));}

catch (Exception ex)

{

Console.WriteLine(ex);

}

}

说明一下“E:\\install\\hanlp”需要把jar包和配置文件,及解压后的data语料库文件夹放在同一目录,该方法其实是通过jvm调用java,使得.net core 能够对其进行方法调用

  1. 关键字提取

Console.WriteLine(HanLP.extractKeyword("商品和服务",2));

输出结果

  1. 汉字转拼音

private static void py()

{

string stringpy = "每个青年都应当有远大的抱负";

//var z = HanLP.convertToPinyinString("报复","",true);

//Console.WriteLine(z);

//汉字转拼音搜索

var listpy = HanLP.convertToPinyinList(stringpy);

Console.WriteLine(listpy);

foreach (var item in listpy.toArray())

{

Console.WriteLine(item);

}

var firstpyt = HanLP.convertToPinyinFirstCharString(stringpy, "", true);

Console.WriteLine(firstpyt);

var firstpyf = HanLP.convertToPinyinFirstCharString(stringpy, " ", false);

Console.WriteLine(firstpyf);

//拼音转汉字

String text = "重载不是重任";

java.util.List pinyinList = HanLP.convertToPinyinList(text);

Console.WriteLine("原文,");

foreach (char c in text.ToCharArray())

{

Console.WriteLine("%c,", c);

}

Console.WriteLine();

Console.WriteLine("拼音(数字音调),");

foreach (Pinyin pinyin in pinyinList.toArray())

{

Console.Write("%s,", pinyin);

}

Console.WriteLine();

Console.WriteLine("拼音(符号音调),");

foreach (Pinyin pinyin in pinyinList.toArray())

{

Console.Write("%s,", pinyin.getPinyinWithToneMark());

}

Console.WriteLine();

Console.WriteLine("拼音(无音调),");

foreach (Pinyin pinyin in pinyinList.toArray())

{

Console.WriteLine("%s,", pinyin.getPinyinWithoutTone());

}

Console.WriteLine();

Console.WriteLine("声调,");

foreach (Pinyin pinyin in pinyinList.toArray())

{

Console.Write("%s,", pinyin.getTone());

}

}

  1. 繁简互转

string fttext = "知識沒有盡頭,就像海沒有邊際";

Console.WriteLine(HanLP.convertToSimplifiedChinese(fttext));

效果如下

  1. 文本推荐,耗时最长,如有解决,烦请指教(未成功)

文本推荐原理

假设“你爱我们”和“我们爱你”进行相似度计算,计算机会将每一句话的每个词,根据语料库进行计算,算出词向量值,在通过对每个词向量进行累加就变成了句向量,再将两个计算的句向量值,进行cos余弦计算,最终得出相似匹配度

先贴代码后赘述

public static Vector query(string content)

{

if (content == null || content.Length == 0)

{ Console.WriteLine("-------------------");return null; }

//对句子进行分词,我爱你们--->["我"、"爱"、"你们"]

object z = NotionalTokenizer.segment(content);//

java.util.List termList = NotionalTokenizer.segment(content);

Vector result = new Vector(200);

int n = 0;

//WordVectorModel wordVectorModelss = new WordVectorModel("en-vectors.txt");

WordVectorModel wordVectorModelss = new WordVectorModel("E:\\install\\hanlp\\data\\model\\sogouyuliaoku.txt");

foreach (Term term in termList.toArray())

{

//从word2vec词典中查出这个词的 词向量

Vector vector = wordVectorModelss.vector(term.word);

if (vector == null)

{

//如果这是一个oov词,则直接忽略

continue;

}

++n;

//将 句子分词后的每个词 的词向量 相加

result.addToSelf(vector);

}

if (n == 0)

{

Console.WriteLine("-------------------");

return null;

}

//归一化

result.normalize();

//句子--->分词--->查询词向量--->词向量相加作为"句向量"

Console.WriteLine(result);

return result;

}

/**

* 文档相似度计算

* @param what

* @param with

* @return

*/

public static float similarity(string what, string with)

{

//what 文档的 向量

Vector A = query(what);

if (A == null) return -1f;

//to 文档的 向量

Vector B = query(with);

if (B == null) return -1f;

//计算余弦相似度

return A.cosineForUnitVector(B);

}

其他均可运行,但通过java.Util对其进行获取WordVectorModel wordVectorModelss = new WordVectorModel("E:\\install\\hanlp\\data\\model\\sogouyuliaoku.txt");

指定语料库时,报错,报错信息如图

Unable to cast object of type 'java.util.PropertyResourceBundle' to type 'sun.util.resources.OpenListResourceBundle'.

对其无法追究其根本,故从java中进行测试,能获取到文件,但同样会报错

报错信息如下

查询具体报错是,大致意思是说足彩这种从文本中获取的文字数据无法计算词向量,计算出的值为-1就报异常,但其实应该是0-9之间的区间值。

AI 智能搜索 开源hanlp实现的更多相关文章

  1. AI 智能写情诗、藏头诗

    一.AI 智能情诗.藏头诗展示 最近使用PyTorch的LSTM训练一个写情诗(七言)的模型,可以随机生成情诗.也可以生成藏头情诗. 在特殊的日子用AI生成一首这样的诗,是不是很酷!下面分享下AI 智 ...

  2. 淘宝购物车页面 智能搜索框Ajax异步加载数据

    如果有朋友对本篇文章的一些知识点不了解的话,可以先阅读此篇文章.在这篇文章中,我大概介绍了一下构建淘宝购物车页面需要的基础知识. 这篇文章主要探讨的是智能搜索框Ajax异步加载数据.jQuery的社区 ...

  3. 【百度地图API】如何区分地址解析和智能搜索?

    原文:[百度地图API]如何区分地址解析和智能搜索? 摘要: 很多用户一直无法区分地址解析geocoder和智能搜索localsearch的使用场景.该文章用一个详尽的示例,充分展示了这两个类,共5种 ...

  4. 实现input输入时智能搜索

    // 智能搜索 function oSearchSuggest(searchFuc) { var input = $('#in'); var suggestWrap = $('#gov_search_ ...

  5. 用人工智能学习,凡亿推出PCB问题解答智能搜索机器人:pcb助手

    对于学习者,你是不是经常遇到这样的问题:在我们狠狠下定决心学习PCB技术的时候,我们常常遇到很多大大小小的问题,遗憾的是身边没有一个能及时给自己解答问题的高手指点,通过论坛.群等方式询问可能半天也得不 ...

  6. AI智能外呼机器人网络拓扑结构笔记

    最近开发了一套AI智能外呼机器人系统,系统主要有3部分组成:web管理平台:呼叫机器人:SIP软交换.具体网络拓扑结构如下图: 三部分主要功能如下: 1.web管理平台:话术管理.任务管理.线路管理. ...

  7. 用电销机器人让电销企业迈入AI智能时代

    2019年是AI智能快速发展的一年,有非常多的企业已经用AI智能代替原有的传统员工做重复性高的工作,就拿销售行业来说,为了让电销员工提升工作效率,拥有更多的成单,大部分有电销岗位的公司都会把重复率较高 ...

  8. 玩转百度地图API(地图,坐标,标记,添加控件,2D图,混合图,智能搜索,地址解析器,信息窗口)

    1.注册得到appkey 2.直接上代码 <!DOCTYPE html> <html> <head> <meta http-equiv="Conte ...

  9. AI智能皮肤测试仪助力美业数字化营销 实现门店与用户双赢局面

    当皮肤遇到AI智能,会有怎么样的火花呢?随着生活水平的提升,人们对肌肤保养护理的需求也越来越高,人要美,皮肤养护也要更精准,数字化必将成为美业发展的新契机.新机遇下肌肤管家SkinRun为美业客户提供 ...

  10. 三分钟玩转微软AI量化投资开源库QLib

    更多精彩内容,欢迎关注公众号:数量技术宅,也可添加技术宅个人微信号:sljsz01,与我交流. 微软QLib简介 微软亚洲研究院发布了 AI 量化投资开源平台"微矿 Qlib".Q ...

随机推荐

  1. 关于el-popover的箭头颜色

    因为会从四个方向不定弹出 所以需要写入4个方向: 注意弹出框是动态插入body中的,需写入根部样式中 如果有多个地方用到且颜色都不一样,可以用类名区分,elm提供了 然后把前面的 .el-popper ...

  2. Fiddler自动响应

    自动响应 自带了几个自动响应的规则: regex:(?inx).+.jpg$ # 以jpg结尾 这里写的是正则表达式,所以如果要拦截其他格式只需要改请求文件的后缀名即可. regex:(?inx).+ ...

  3. Jest - Testing Asynchronous

    When we test asynchronous, we use Axios to get the response. install the Axios npm i axios Cause we ...

  4. Unity 打包到XCode自动化设置参数

    [PostProcessBuild] public static void OnPostprocessBuild(BuildTarget buildTarget, string buildPath) ...

  5. Ubuntu18.04LTS虚拟机优化

    1.没网 刚安装好没网,可以设置NAT连接,也可以直接设置为桥接模式联网.这里直接桥接. 网络中心使用的是以太网,所以就在菜单的"编辑"里的"虚拟网络编辑器"里 ...

  6. react框架-知识点(ref,, setState)

    react的思想:无必要勿增实体 1. ref 使用 myRef = React.createRef() <input ref={this.myRef}></input> 2. ...

  7. 如何实现chrome谷歌浏览器多开(独立环境 独立cookie)、改任务栏图标

    多开谷歌浏览器: 由于各种各样的原因,你可能需要在一个电脑登录某个平台,比如一个电脑登录3个公众号,或者3个知乎等等. 最简单的方案是,直接安装3个不同的浏览器,比如一个谷歌浏览器,一个火狐浏览器,一 ...

  8. Flink Table API & SQL 自定义Redis Sink 使用方式

    flink-connector-redis的使用方式和其他连接器几乎一样,除了一些公共的参数外(connector.type, format.type, or update-mode等),还支持以下参 ...

  9. OS-lab4

    OS-lab4 系统调用 系统调用的流程 按照上述的流程逐个分析. user/syscall_lib.c 这个文件位于user文件夹下,也就是用户程序可以调用的函数,相当于操作系统提供给用户程序的一些 ...

  10. springMVC学习day02

    了解springMVC 1. 了解官网 1.  首先到spring地址去,然后选择项目下面的任何一个子项目,我选择spring framework https://spring.io/ 2.选择spr ...