MaxCompute UDF系列之判断字符串中是否包含汉字

    xiaoxiao2021-07-08  227

    为了验证字符串中是否包含中文汉字,今天为大家提供一个自动判断中文字符的MaxCompute UDF,下载地址见附件。

    效果如下:

    MaxCompute UDF代码如下:

    package com.yinlin.udf.dev; import com.aliyun.odps.udf.UDF; // 根据Unicode编码完美的判断中文汉字和符号 public class Han extends UDF { public String evaluate(String inputHan){ if (inputHan == null) {return inputHan;} char[] input = inputHan.trim().toCharArray(); for (int i = 0; i < input.length; i++) { Character.UnicodeBlock ub = Character.UnicodeBlock.of(input[i]); if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_B || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION) { //System.out.println(input[i]); return "1"; } } return "0"; } }

    使用方法:

    1、通过Eclipse将Han.java编译成Jar包,命名为han_udf.jar。

    2、通过大数据开发套件,上传资源han_udf.jar;

    3、通过大数据开发套件,引用第二步上传的han_udf.jar资源,注册han函数;

    4、通过大数据开发套件新建SQL脚本,输入SQL函数进行测试。

    --创建虚拟表 CREATE TABLE IF NOT EXISTS dual (id STRING); insert into table dual select '1' from (select count(1) from dual) t; --根据Unicode编码完美的判断中文汉字和符号 select han('yinLin123%') from yinlin_demo.dual limit 1; --根据Unicode编码完美的判断中文汉字和符号 select han('隐林yinLin123%') from yinlin_demo.dual limit 1;

    到此为止,实验完成。

    常见问题

    Q:无结果?

    我们在创建虚拟dual表的时候,一定要保证表中有数据。

    Q:无法找到han函数?

    利用大数据开发套件注册han函数的时候需要包名+类名,否则会找不到类。

    阿里巴巴大数据-玩家社区 https://yq.aliyun.com/teams/6/

    ---阿里大数据博文,问答,社群,实践,有朋自远方来,不亦说乎……

    相关资源:七夕情人节表白HTML源码(两款)

    最新回复(0)