适合初学者
引入类库:fr-core-8.0.jar
code:
//my frist code for fr 2016-11-28;
package com.fr.function;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import com.fr.script.*;
public class Cny extends AbstractFunction {
@Override
public Object run(Object args) {
Object para;//接收参数
String Cnys="";
for (int i = 0; i < args.length; i++) {
para = args;
Cnys =para.toString();//取出参数
}
if (Cnys==""){
Cnys="ppp";
} //参数为空
Cnys =Cpy(Cnys);//调用函数
return Cnys;
}
//用于测试输出
// public static void main(String args) {
// String p="Cnys";
//Lib cn1=new Lib();
// System.out.println(Cpy(p));
// }
//}
//用于测试输出
// class Lib{
private static int BEGIN = 45217;
private static int END = 63486;
// 按照声 母表示,这个表是在GB2312中的出现的第一个汉字,也就是说“啊”是代表首字母a的第一个汉字。
// i, u, v都不做声母, 自定规则跟随前面的字母
private static char chartable = { '啊', '芭', '擦', '搭', '蛾', '发', '噶', '哈', '哈', '击', '喀', '垃', '妈', '拿', '哦', '啪',
'期', '然', '撒', '塌', '塌', '塌', '挖', '昔', '压', '匝', };
// 二十六个字母区间对应二十七个端点
// GB2312码汉字区间十进制表示
private static int table = new int;
// 对应首字母区间表
private static char initialtable = { 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'h', 'j', 'k', 'l', 'm', 'n', 'o',
'p', 'q', 'r', 's', 't', 't', 't', 'w', 'x', 'y', 'z', };
// 初始化
static {
for (int i = 0; i < 26; i++) {
table = gbValue(chartable);// 得到GB2312码的首字母区间端点表,十进制。
}
table = END;// 区间表结尾
}
public static String Dms(String pk) {
Date date = new Date();
pk = (new SimpleDateFormat("yyyyMMddhhmmssSSS")).format(date);
return pk;
}
// ------------------------public方法区------------------------
// 根据一个包含汉字的字符串返回一个汉字拼音首字母的字符串 最重要的一个方法,思路如下:一个个字符读入、判断、输出
public static String Cpy(String SourceStr) {
String Result = "";
int StrLength = SourceStr.length();
int i;
try {
for (i = 0; i < StrLength; i++) {
Result += Caz(SourceStr.charAt(i));
}
} catch (Exception e) {
Result = "";
e.printStackTrace();
}
return Result + Dms("now");
}
// ------------------------private方法区------------------------
/**
* 输入字符,得到他的声母,英文字母返回对应的大写字母,其他非简体汉字返回 '0' *
*/
private static char Caz(char ch) {
// 对英文字母的处理:小写字母转换为大写,大写的直接返回
if (ch >= 'a' && ch <= 'z') {
return (char) (ch - 'a' + 'A');
}
if (ch >= 'A' && ch <= 'Z') {
return ch;
}
// 对非英文字母的处理:转化为首字母,然后判断是否在码表范围内,
// 若不是,则直接返回。
// 若是,则在码表内的进行判断。
int gb = gbValue(ch);// 汉字转换首字母
if ((gb END)) // 在码表区间之前,直接返回
{
return ch;
}
int i;
for (i = 0; i < 26; i++) {// 判断匹配码表区间,匹配到就break,判断区间形如“[,)”
if ((gb >= table) && (gb < table)) {
break;
}
}
if (gb == END) {// 补上GB2312区间最右端
i = 25;
}
return initialtable; // 在码表区间中,返回首字母
}
/**
* 取出汉字的编码CN 汉字
*/
private static int gbValue(char ch) {// 将一个汉字(GB2312)转换为十进制表示。
String str = new String();
str += ch;
try {
byte bytes = str.getBytes("GB2312");
if (bytes.length < 2) {
return 0;
}
return (bytes << 8 & 0xff00) + (bytes & 0xff);
} catch (Exception e) {
return 0;
}
}
}