class Helper_Spell{
public $spellArray = array();
static public function getArray() {
return unserialize(file_get_contents('pytable_without_tune.txt'));
}
/**
* @desc 文字列の最初の文字を取得します
* @param $string 変換する文字列
* @param $isOne 最初の文字を取得するかどうか
* 例: get ChineseFirstChar('I am the author') 最初の文字はすべての文字 + 小文字です
* return "wo"
*
* 例: get ChineseFirstChar('I am the author', true) 最初の文字は最初の文字 + 小文字です
* return "w"
*
* For例: get ChineseFirstChar('I am the author', true, true) 最初の文字の最初の文字 + 大文字
* "W" を返す
*
すべての文字 + 大文字
*「WO」を返します
*/
static public function get ChineseFirstChar($string,$isOne=false,$upper=false) {
$spellArray = self::getArray();
$str_arr = self::utf8_str_split($string,1); //将字符串拆分成数组
if(preg_match('/^[x{4e00}-x{9fa5}]+$/u',$str_arr[0])) { //判断の有無は汉字
$chinese = $spellArray[$str_arr[0]];
$result = $chinese[0];
}else {
$result = $str_arr[0];
}
$result = $は一つですか? substr($result,0,1) : $result;
return $upper?strtoupper($result):$result;
}
/**
* @desc 文字列をピンイン文字列に変換します
* @param $string 中国語文字列
* @param $upper 大文字にするかどうか
* @文字列 + 小文字
* return "wo shi zuo zhe" *
* * たとえば: get ChineseChar('私は著者です', true); 最初の文字 + 小文字
* return "w s z z"
* *
* 例: get ChineseChar('私は著者です',true,true); * return "W S Z Z"
* *
* 例: get ChineseChar('I am the author',false,true); 頭文字 + 大文字
* return "WO SHI ZUO ZHE "
*/
static public function get ChineseChar($string,$isOne=false,$upper=false) {
global $ SpellArray;
$str_arr = self::utf8_str_split($string,1); //将字符串拆分成数组
$result = array();
foreach($str_arr as $char)
{
if(preg_match('/^[x{4e00}-x{9fa5}]+$/) u',$char))
{
$chinese = $spellArray[$char];
$chinese = $chinese[0];
}else{
$chinese=$char;
}
$chinese = $isOne ? substr($chinese,0,1) : $chinese;
$result[] = $upper ? strtoupper($chinese) : $chinese;
}
return implode(' ',$result);
}
/**
* @desc文字列を配列に変換する
* @param $ str変換する配列*/
プライベート関数 utf8_str_split($str,$split_len=1) {
if(!preg_match('/^[0-9]+$/', $split_len) || $split_len < 1) {
return FALSE; }
$len = mb_strlen($str, 'UTF- 8');
if ($len return array($str);
}
preg_match_all('/.{'.$split_len.'}|[^x00]{1,' .$split_len.'}$/us', $str, $ar);
return $ar[0];
}
}