备注:win7 64位系统,netbeans编程

NLPIR分词系统,前身是2000年发布的ICTCLAS,2009年更为现名。张华平博士打造。

实现步骤

1、在Netbeans中,文件→新建项目→java→java应用程序;项目名称:CWordSeg;
    2、将NLPIR文件下…\sample\JnaTest_NLPIR\src\code中NlpirTest.java里的代码拷贝到CWordSeg.java里面;

初步修改代码为下图所示:

(1)将package包声明修改为cwordseg;
    (2)将类名NlpirTest重命名重构为CWordSeg;
    方法:右键CwordSeg.java→重构→重命名,改名为CWordSeg→重构;

如果只是直接修改代码里的类名,则仍然需要进行重构,否则运行时会报错:找不到主类CWordSeg。
    (3)import utils.SystemParas; 未用到,暂时注释掉。

3、将NLPIR文件下…\sample\JnaTest_NLPIR\src下的utils文件夹直接拷贝到项目CWordSeg的src文件夹中;

4、将NLPIR文件下…\sample\JnaTest_NLPIR\lib下的jna-4.0.0.jar导入到工程库中;
    方法(1):右键库→添加JAR→选择jna-4.0.0.jar导入;
    方法(2):直接复制jna-4.0.0.jar文件到工程…\CWordSeg\lib文件夹下。
    导完之后工程目录如下:

5、在工程CWordSeg文件夹中新建文件夹file:
    (1)将NLPIR中的Data文件夹全部拷贝到file文件夹中;
    (2)将…\lib\win64文件夹也全部拷贝到file文件夹(注意:如果是win32或linux请选择对应的文件夹)。

6、修改部分代码2:
    (1)修改文件NLPIR.dll所在的路径,它在第5步中拷入的win64文件夹中,例如:
    D:\\NetBeansProjects\\CWordSeg\\file\win64\\NLPIR
    注意:最后的NLPIR是文件名,不要加后缀.dll。
    附:已经试验过,如果是64位操作系统,使用32位的文件将会报错。

(2)修Data文件夹所在的路径(即第5步中的Data文件夹),如下图所示:
    D:\\NetBeansProjects\\CWordSeg\\file

(3)其他可以更改的地方:
    编码格式:int charset_type = 1; 改为其它值。
    其中:GBK对应0,UTF-8对应1,BIG5对应2,含繁体字的GBK对应3。

简化后代码如下

  1.  package cwordseg;  
    
     import java.io.UnsupportedEncodingException;
    // import utils.SystemParas;
    import com.sun.jna.Library;
    import com.sun.jna.Native; /**
    *
    * 功能:基本的分词功能
    * 最后更新时间:2016年3月14日 21:01:21
    */ public class CWordSeg {
    // 定义接口CLibrary,继承自com.sun.jna.Library
    public interface CLibrary extends Library {
    // 定义并初始化接口的静态变量,用于加载NLPIR.dll,路径指向文件NLPIR.dll,但不加后缀dll
    CLibrary Instance = (CLibrary) Native.loadLibrary("D:\\NetBeansProjects\\CWordSeg\\file\\win64\\NLPIR",CLibrary.class);
    // 初始化函数声明:sDataPath是初始化路径地址,包括核心词库和配置文件的路径,encoding为输入字符的编码格式
    public int NLPIR_Init(String sDataPath,int encoding,String sLicenceCode);
    // 分词函数声明:sSrc为待分字符串,bPOSTagged=0表示不进行词性标注,bPOSTagged=1表示进行词性标注
    public String NLPIR_ParagraphProcess(String sSrc,int bPOSTagged);
    // 获取最后一个错误信息的函数声明
    public String NLPIR_GetLastErrorMsg();
    // 退出函数声明
    public void NLPIR_Exit();
    } public static String transString(String aidString,String ori_encoding,String new_encoding) {
    try {
    return new String(aidString.getBytes(ori_encoding),new_encoding);
    } catch (UnsupportedEncodingException e) {
    e.printStackTrace();
    }
    return null;
    } public static void main(String[] args) throws Exception {
    String argu = "D:\\NetBeansProjects\\CWordSeg\\file"; // 该路径指向Data文件夹(系统核心词库)
    // String system_charset = "UTF-8";
    int charset_type = 1; // UTF-8编码模式,其它的GBK对应0,BIG5对应2,含繁体字的GBK对应3
    int init_flag = CLibrary.Instance.NLPIR_Init(argu, charset_type, "0"); // 运行初始化函数,成功则返回1,失败返回0
    String nativeBytes; // 初始化失败提示
    if (0 == init_flag) {
    nativeBytes = CLibrary.Instance.NLPIR_GetLastErrorMsg(); // 获取错误信息
    System.err.println("初始化失败!原因:"+nativeBytes);
    return;
    } String sInput = "这是一本关于信息检索的书。"; // 手工输入的字符串sInput
    try {
    nativeBytes = CLibrary.Instance.NLPIR_ParagraphProcess(sInput, 1); // 运行分词函数
    System.out.println("分词结果为: " + nativeBytes); // 输出分词结果
    CLibrary.Instance.NLPIR_Exit(); // 退出
    } catch (Exception ex) {
    // TODO Auto-generated catch block
    ex.printStackTrace();
    }
    }
    }

运行结果

出错解决:找不到主类CWordSeg

在第2步中修改了类名,需要用正确的方法修改,或者通过重构修正。

1---------java调用NLPIR(ICTCLAS2016)实现分词功能的更多相关文章

  1. ZH奶酪:Java调用NLPIR汉语分词系统

    NLPIR工具 支持自定义词表: 可以离线使用: 下载地址:http://ictclas.nlpir.org/newsdownloads?DocId=389 在线演示:http://ictclas.n ...

  2. 2------------NLPIR(ICTCLAS2016)分词系统添加用户词典功能

    备注:win7 64位系统,netbeans编程 基本代码框架参见我的另一篇文章:NLPIR分词功能 代码实现: package cwordseg; import java.io.Unsupporte ...

  3. Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结

    Atitit java c# php c++ js跨语言调用matlab实现边缘检测等功能attilax总结 1.1. 边缘检测的基本方法Canny最常用了1 1.2. 编写matlab边缘检测代码, ...

  4. 将封装了envi功能的IDL类导出成java类,方便java调用

    目的:     用IDL将ENVI的功能封装成为IDL的类,并使用IDL的对象导出功能把这些功能类导出为java类,方便java调用.(本来想直接通过GP工具调用的,但是没有授权文件)   操作步骤: ...

  5. xmlrpc实现bugzilla api调用(无会话保持功能,单一接口请求)

    xmlrpc实现bugzilla4   xmlrpc api调用(无会话保持功能,单一接口请求),如需会话保持,请参考我的另外一篇随笔(bugzilla4的xmlrpc接口api调用实现分享: xml ...

  6. Java调用C/C++编写的第三方dll动态链接库(zz)

    这里主要用的方法是JNI.在网上查资料时看到很多人说用JNI非常的复杂,不仅要看很多的文档,而且要非常熟悉C/C++编程.恐怕有很多人在看到诸如此类的评论时已经决定绕道用其他方法了.本文将做详细的介绍 ...

  7. Rsession让Java调用R更简单

    Rsession让Java调用R更简单 R的极客理想系列文章,涵盖了R的思想,使用,工具,创新等的一系列要点,以我个人的学习和体验去诠释R的强大. R语言作为统计学一门语言,一直在小众领域闪耀着光芒. ...

  8. java 调用webservice的各种方法总结

    java 调用webservice的各种方法总结 几种流行的开源WebService框架Axis1,Axis2,Xfire,CXF,JWS比较 方法一:创建基于JAX-WS的webservice(包括 ...

  9. paip.java 调用c++ dll so总结

    paip.java 调用c++ dll so总结 ///////JNA (这个ms sun 的) 我目前正做着一个相关的项目,说白了JNA就是JNI的替代品,以前用JNI需要编译一层中间库,现在JNA ...

随机推荐

  1. InfluxDB学习之InfluxDB的基本操作

    InfluxDB提供类SQL语法,如果熟悉SQL的话会非常容易上手.本文就为大家介绍一下InfluxDB的基本操作.     InfluxDB提供类SQL语法,如果熟悉SQL的话会非常容易上手. 本文 ...

  2. Android提升篇系列:Activity recreate(Activity 重新创建/自我恢复)机制(一)

    注:本文中的recreate是指当内存不足时,Activity被回收,但再次来到此Activity时,系统重新恢复的过程.例如:当Activity A到Activity B时,如果内存不足,A被回收, ...

  3. 你可能不需要 jQuery!使用原生 JavaScript 进行开发

    很多的 JavaScript 开发人员,包括我在内,都很喜欢 jQuery.因为它的简单,因为它有很多丰富的插件可供使用,和其它优秀的工具一样,jQuery 让我们开发人员能够更轻松的开发网站和 We ...

  4. [deviceone开发]-do_GridView的简单示例

    一.简介 do_GridView的高度支持-1,根据gridview里item的个数来决定gridview的高度,这样gridview自身就无法滚动了,需要放到固定高度的scrollview里才能滚动 ...

  5. javascript 函数初探 (六)--- 闭包初探#4

    循环中的闭包: 让我们来看一下一个会循环三次的操作,她在每次迭代中都会创建一个返回当前序列号的新函数,该函数会被添加到一个数组中,并最终返回: function F(){ var arr = [], ...

  6. iOS 适配iOS9

    1.网络接口不支持https协议,在iOS9下 在iOS9下,系统默认会拦截对http协议接口的访问,因此无法获取http协议接口的数据. 解决方案(以下方法2选1): (1)暂时退回到http协议 ...

  7. atitit.身份认证解决方案attilax总结

    atitit.身份认证解决方案attilax总结 1.1. 身份认证1 1.2.  basic认证1 1.2.1. 编程实现basic客户端2 1.3. digest认证机制3 1.4. SSL认证3 ...

  8. 手把手系列:实现Nat地址转换

    1.实验目的: 掌握内网中的主机C1连接到Internet时,通过NAT实现私有全局地址转换.   2.实验拓扑: 3.实验步骤: 步骤一:给主机C1和C2配置IP地址.子网掩码和网关.如图: C1: ...

  9. ubuntu环境变量

    在Ubuntu中有如下几个文件可以设置环境变量1./etc/profile:在登录时,操作系统定制用户环境时使用的第一个文件,此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行.2. ...

  10. Android Animation学习(二) ApiDemos解析:基本Animators使用

    Android Animation学习(二) ApiDemos解析:基本Animatiors使用 Animator类提供了创建动画的基本结构,但是一般使用的是它的子类: ValueAnimator.O ...