zoukankan      html  css  js  c++  java
  • Atitit.atiInputMethod v2词库清理策略工具    q229

    Atitit.atiInputMethod v2词库清理策略工具    q229

     

     

    1.1. Foreigncode 外码清理1

    1.2. 垃圾词澄清1

     

    1.1. Foreigncode 外码清理

    Only can Ascii and num 

    Before Be4  

    For  4

     

     

     

    1.2. 垃圾词澄清

    Tool  long 

     

    Not  common wordlib (3000-5000)

     

    作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

    转载请注明来源: http://blog.csdn.net/attilax

     

    1.3. Code---

    package com.attilax.inputmethod;

     

    import java.io.File;

    import java.io.IOException;

    import java.util.ArrayList;

     

    import org.apache.commons.lang3.StringUtils;

     

    import com.attilax.io.FileLineTraver;

    import com.attilax.io.filex;

    import com.attilax.lang.text.strUtil;

    import com.google.common.collect.Lists;

     

    public class WordlibClrNTrim {

     

    public static void main(String[] args) throws IOException {

    String expWordlibDir = "C:\\Users\\Administrator.ATTILAXPC188\\Documents\\[ atian inputmethod ]\\";

    expWordlibDir = "C:\\Users\\Administrator\\Documents\\[ atian attilax ]\\";

    String strPath = expWordlibDir + "导出 全部词条.txt";

    if (!new File(strPath).exists())

    throw new RuntimeException("file not exist");

     

    String fileName = "c:\\wordlib" + filex.getUUidName() + ".txt";

    System.out.println(fileName);

    String encode = "unicode";

    encode = "utf-8";

    filex fc = new filex(fileName, encode);

    FileLineTraver.trav(strPath, encode, (line) -> {

    String[] a = line.toString().split("\t");

     

    if (a.length < 2)

    return line;

     

    String forighCodePix = a[1];

    String[] forighCode_arr = get_forighCode_arr(forighCodePix);

     

     

    String forighCode = forighCode_arr[0].trim();

    if (forighCode.length() == 0

    || !StringUtils.isAlphanumeric(forighCode)) // err

    // foreigh

    // code

    {

    System.out.println(line);

    return "";

    }

     

    // new line

    String Char = a[0];

    String newLine = Char + "\t" + forighCode.trim()

    + forighCode_arr[1].trim();

    fc.append_HP_Safe(newLine + "\r\n");

    return line;

     

    });

    fc.closeSF();

    System.out.println("--f");

    }

     

    private static String[] get_forighCode_arr(String forighCodePix) {

    int SharpCharINdex = forighCodePix.indexOf("#");

    String[] a = { "", "" };

    a[0] = forighCodePix.substring(0, SharpCharINdex);

    a[1] = forighCodePix.substring(SharpCharINdex);

    return a;

    }

     

    }

     

     

  • 相关阅读:
    Linux下semaphore的使用 进程间互斥的一个好方法
    CURL编程:什么是NonASCII平台,如何取得页面的charset
    C++中的重载(Overload), 覆盖(Override)和隐藏(Hide)
    system调用虽然用了exec,但是fd, signal这些还是会保留父进程的,be careful
    addr2line,可以根据一个地址打印出对应的代码行
    POSIX Threads Programming 阅读笔记(来自劳伦斯利物浦实验室的文章)
    [Gammu]setlocale和bindtextdomain函数的用法
    常用编码
    用PL/SQL画直方图
    窗体的关闭
  • 原文地址:https://www.cnblogs.com/attilax/p/15198694.html
Copyright © 2011-2022 走看看