为了验证字符串中是否包含中文汉字,今天为大家提供一个自动判断中文字符的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函数的时候需要包名+类名,否则会找不到类。