zoukankan      html  css  js  c++  java
  • 汉字转拼音---PHP

    思路:

    在文件中放入一个UTF-8的中文汉字与拼音对照的文件。在汉字转拼音时,只要用正则匹配到对照文件的相应的汉字,就能得到拼音。

    汉字与拼音对照文件下载地址:链接:https://pan.baidu.com/s/1kIgGmP7mAKnRbchetqXrwQ 密码:6ezn

    汉字转拼音类:

    <?php
    /**
    *
    * 汉字转拼音类
    * @Author : Kin
    * @Date   : 2014-03-16
    * @Email  : Mr.kin@foxmail.com
    *
    */
    
    class ChinesePinyin{
        
        //utf-8中国汉字集合
        private $ChineseCharacters;
        //编码
        private $charset = 'utf-8';
        
        public function __construct(){
            if( empty($this->ChineseCharacters) ){
             $this->ChineseCharacters = file_get_contents('ChineseCharacters.dat','r');
            }
        }
        
        /*
        * 转成带有声调的汉语拼音
        * param $input_char String  需要转换的汉字
        * param $delimiter  String   转换之后拼音之间分隔符
        * param $outside_ignore  Boolean     是否忽略非汉字内容
        */
        public function TransformWithTone($input_char,$delimiter='',$outside_ignore=false){
            
            $input_len = mb_strlen($input_char,$this->charset);
            $output_char = '';
            for($i=0;$i<$input_len;$i++){
                $word = mb_substr($input_char,$i,1,$this->charset);
                if(preg_match('/^[x{4e00}-x{9fa5}]$/u',$word) && preg_match('/\,'.preg_quote($word).'(.*?)\,/',$this->ChineseCharacters,$matches) ){
                    $output_char.=$matches[1].$delimiter;
                }else if(!$outside_ignore){
                    $output_char.=$word;
                }
            }
            
            return $output_char;
        }
        
        /*
        * 转成带无声调的汉语拼音
        * param $input_char String  需要转换的汉字
        * param $delimiter  String   转换之后拼音之间分隔符
        * param $outside_ignore  Boolean     是否忽略非汉字内容
        */    
        public function TransformWithoutTone($input_char,$delimiter='',$outside_ignore=true){
            
            $char_with_tone = $this->TransformWithTone($input_char,$delimiter,$outside_ignore);
            
            $char_without_tone  =  str_replace(array('ā','á','ǎ','à','ō','ó','ǒ','ò','ē','é','ě','è','ī','í','ǐ','ì','ū','ú','ǔ','ù','ǖ','ǘ','ǚ','ǜ','ü'),
                                               array('a','a','a','a','o','o','o','o','e','e','e','e','i','i','i','i','u','u','u','u','v','v','v','v','v')
                                               ,$char_with_tone );
            return $char_without_tone;
            
        }
        
        /*
        * 转成汉语拼音首字母
        * param $input_char String  需要转换的汉字
        * param $delimiter  String   转换之后拼音之间分隔符
        */    
        public function TransformUcwords($input_char,$delimiter=''){
            
            $char_without_tone = ucwords($this->TransformWithoutTone($input_char,' ',true));
            $ucwords = preg_replace('/[^A-Z]/','',$char_without_tone);
            if(!empty($delimiter)){
                $ucwords = implode($delimiter,str_split($ucwords));
            }
            return strtolower($ucwords);        
        }
        
    }
  • 相关阅读:
    Actioin<T>委托
    StructLayout特性、、、MashalAs
    ibatis.net存储过程:SqlParameterCollection 中未包含带有 ParameterName“@”的 SqlParamer
    Jquery扩展方法
    XML学习
    CSS实现文字阴影
    FTP概述
    Ajax使用PageMethods调用后台方法
    JSP连接SQL2008
    Ajax Sys.UI.DomElement学习
  • 原文地址:https://www.cnblogs.com/Mr-Wenyan/p/9039946.html
Copyright © 2011-2022 走看看