婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > PHP切割漢字的常用方法實(shí)例總結(jié)

PHP切割漢字的常用方法實(shí)例總結(jié)

熱門(mén)標(biāo)簽:地下城堡2圖九地圖標(biāo)注 保定crm外呼系統(tǒng)運(yùn)營(yíng)商 海南人工外呼系統(tǒng)有效果嗎 七魚(yú)外呼系統(tǒng)停用嗎 抖音有個(gè)地圖標(biāo)注是什么意思 阿里云400電話(huà)申請(qǐng)加工單 九江外呼系統(tǒng) 西區(qū)企業(yè)怎么做地圖標(biāo)注入駐 智能電話(huà)機(jī)器人排名前十名南京

本文實(shí)例講述了PHP切割漢字的常用方法。分享給大家供大家參考,具體如下:

?php
/*
@UTF-8編碼的字符可能由1~3個(gè)字節(jié)組成。
*/
/*--------------------------方法一截取中文字符串方法------------------------------*/
function msubstr($str, $start, $len)
{
  $tmpstr = "";
  $strlen = $start + $len;
  for ($i = 0; $i  $strlen; $i++) {
    if (ord(substr($str, $i, 1)) > 0xa0)  //ord()函數(shù)返回字符串的第一個(gè)字符的ASCII值
    {
      $tmpstr .= substr($str, $i, 2);
      $i++;
    } else {
      $tmpstr .= substr($str, $i, 1);
    }
  }
  return $tmpstr;
}
/*----------------------------第二種方法-----------------------------------*/
//截取的是UTF-8字符串
function utf_substr($str, $len)
{
  $new_str = [];
  for ($i = 0; $i  $len; $i++) {
    $tem_str = substr($str, 0, 1);
    if (ord($tem_str > 127)) {
      $i++;
      if ($i  $len) {
        $new_str[] = substr($str, 0, 3);
        $str = substr($str, 3);
      }
    } else {
      $new_str[] = substr($str, 0, 1);
      $str = substr($str, 1);
    }
  }
  return join($new_str);//join()函數(shù)把數(shù)組元素組合為一個(gè)字符串
}
/*-------------------------------------第三種方法(UTF-8)--------------------------------*/
function cutstr($string, $length)
{
  preg_match_all("/[\x01-\x7f]|[\xc2-\xdf]|[\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/", $string, $info);
  $wordscut = "";
  $j = 0;
  for ($i = 0; $i  count($info[0]); $i++) {
    $wordscut .= $info[0][$i];
    $j = ord($info[0][$i]) > 127 ? $j + 2 : $j + 1;
    if ($j > $length - 3) {
      return $wordscut . "...";
    }
  }
  return join('', $info[0]);
}
$string = "312哈哈,這個(gè)組合很難切割哦";
echo cutstr($string, 10);
/*---------------------------------下面是曾經(jīng)用過(guò)的截取第三個(gè)的字符串的------------------------------*/
// $name1 = mysql_result($my_rst,0,"name");
// $name = preg_match("/([1-9][0-9]+)/",$name1,$r);
// $name = $r[0];
// if($name == ""){
// $name=preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,2}'.
// '((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,1}).*#s',
// '$1',$name1);
// }
/*--------------------------------------------第四種方法(UTF-8)---------------------------------------------*/
function cut_str($sourcestr, $cutlength)
{
  $returnstr = '';
  $i = 0;
  $n = 0;
  $str_length = strlen($sourcestr);//字符串的字節(jié)數(shù)
  while ($n  $cutlength  $i = $str_length) {
    $temp_str = substr($sourcestr, $i, 1);
    $ascnum = ord($temp_str);//得到字符串中第$i位字符的ASCII碼
    if ($ascnum >= 224) {
      $returnstr = $returnstr . substr($sourcestr, $i, 3);//根據(jù)UTF-8編碼規(guī)范,將3個(gè)連續(xù)的字符計(jì)為單個(gè)字符
      $i = $i + 3;//實(shí)際Byte記為3
      $n++;//字串長(zhǎng)度為1
    } elseif ($ascnum >= 192)//如果ASCII位高于192
    {
      $returnstr = $returnstr . substr($sourcestr, $i, 2);//根據(jù)UTF-8編碼規(guī)范,將2個(gè)連續(xù)的字符記為單個(gè)字符
      $i = $i + 2;//實(shí)際Byte記為2
      $n++;//字串長(zhǎng)度為1
    } elseif ($ascnum >= 65  $ascnum = 90)//如果是大寫(xiě)字母
    {
      $returnstr = $returnstr . substr($sourcestr, $i, 1);
      $i = $i + 1;//byte記為1
      $n++;//但考慮到整體美觀,大寫(xiě)字母計(jì)成一個(gè)高位字符
    } else {
      $returnstr = $returnstr . substr($sourcestr, $i, 1);
      $i = $i + 1;//實(shí)際的Byte記為1
      $n = $n + 0.5;//小寫(xiě)字母和半角標(biāo)點(diǎn)等與半個(gè)高位字符寬...
    }
  }
  if ($str_length > $cutlength) {
    $returnstr = $returnstr . "...";//超過(guò)長(zhǎng)度時(shí)在尾處加上省略號(hào)
  }
  return $returnstr;
}
/*--------------------第五種方法(UTF-8)---------------------------------------------*/
function FSubstr($title, $start, $len = "", $magic = true)
{
  if ($len == "") $len = strlen($title);
  if ($start != 0) {
    $startv = ord(substr($title, $start, 1));
    if ($startv >= 128) {
      if ($startv  192) {
        for ($i = $start - 1; $i > 0; $i--) {
          $tempv = ord(substr($title, $i, 1));
          if ($tempv >= 192) break;
        }
        $start = $i;
      }
    }
  }
  if (strlen($title) = $len) return substr($title, $start, $len);
  $alen = 0;
  $blen = 0;
  $realnum = 0;
  $length = 0;
  for ($i = $start; $i  strlen($title); $i++) {
    $ctype = 0;
    $cstep = 0;
    $cur = substr($title, $i, 1);
    if ($cur == "") {
      if (substr($title, $i, 4) == "lt;") {
        $cstep = 4;
        $length += 4;
        $i += 3;
        $realnum++;
        if ($magic) {
          $alen++;
        }
      } elseif (substr($title, $i, 4) == "gt;") {
        $cstep = 4;
        $length += 4;
        $i += 3;
        $realnum++;
        if ($magic) {
          $alen++;
        }
      } elseif (substr($title, $i, 5) == "") {
        $cstep = 5;
        $length += 5;
        $i += 4;
        $realnum++;
        if ($magic) {
          $alen++;
        }
      } elseif (substr($title, $i, 6) == "quot;") {
        $cstep = 6;
        $length += 6;
        $i += 5;
        $realnum++;
        if ($magic) {
          $alen++;
        }
      } elseif (preg_match("/#(\d+);?/i", substr($title, $i), $match)) {
        $cstep = strlen($match[0]);
        $length += strlen($match[0]);
        $i += strlen($match[0]) - 1;
        $realnum++;
        if ($magic) {
          $blen++;
          $ctype = 1;
        }
      }
    } else {
      if (ord($cur) >= 252) {
        $cstep = 6;
        $length += 6;
        $i += 5;
        $realnum++;
        if ($magic) {
          $blen++;
          $ctype = 1;
        }
      } elseif (ord($cur) >= 248) {
        $cstep = 5;
        $length += 5;
        $i += 4;
        $realnum++;
        if ($magic) {
          $ctype = 1;
          $blen++;
        }
      } elseif (ord($cur) >= 240) {
        $cstep = 4;
        $length += 4;
        $i += 3;
        $realnum++;
        if ($magic) {
          $blen++;
          $ctype = 1;
        }
      } elseif (ord($cur) >= 224) {
        $cstep = 3;
        $length += 3;
        $i += 2;
        $realnum++;
        if ($magic) {
          $ctype = 1;
          $blen++;
        }
      } elseif (ord($cur) >= 192) {
        $ctype = 2;
        $length += 2;
        $i += 1;
        $realnum++;
        if ($magic) {
          $blen++;
          $ctype = 1;
        }
      } elseif (ord($cur) >= 128) {
        $length += 1;
      } else {
        $cstep = 1;
        $length += 1;
        $realnum++;
        if ($magic) {
          if (ord($cur) >= 65  ord($cur) = 90) {
            $blen++;
          } else {
            $alen++;
          }
        }
      }
    }
    if ($magic) {
      if (($blen * 2 + $alen) == ($len * 2)) break;
      if (($blen * 2 + $alen) == ($len * 2) + 1) {
        if ($ctype == 1) {
          $length -= $cstep;
          break;
        } else {
          break;
        }
      }
    } else {
      if ($realnum == $len) break;
    }
  }
  unset($cur);
  unset($alen);
  unset($blen);
  unset($realnum);
  unset($ctype);
  unset($cstep);
  return substr($title, $start, $length);
}
function utf8Substr($str, $from, $len)
{
  return preg_replace('#^(?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,' . $from . '}' .
    '((?:[\x00-\x7F]|[\xC0-\xFF][\x80-\xBF]+){0,' . $len . '}).*#s',
    '$1', $str);
}
$title = "你哈珀niad1納斯達(dá)wop asdni你愛(ài)誰(shuí)都沒(méi)阿斯頓撒旦12ccs- sd";
$title = utf8Substr($title, 0, 15);
echo $title;
?>

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php常用函數(shù)與技巧總結(jié)》及《PHP錯(cuò)誤與異常處理方法總結(jié)》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • php使用自定義函數(shù)實(shí)現(xiàn)漢字分割替換功能示例
  • php自定義函數(shù)截取漢字長(zhǎng)度
  • PHP截取漢字亂碼問(wèn)題解決方法mb_substr函數(shù)的應(yīng)用
  • php判斷輸入是否是純數(shù)字,英文,漢字的方法
  • 支持生僻字且自動(dòng)識(shí)別utf-8編碼的php漢字轉(zhuǎn)拼音類(lèi)
  • php中將漢字轉(zhuǎn)換成拼音的函數(shù)代碼
  • PHP版 漢字轉(zhuǎn)碼的實(shí)現(xiàn)詳解
  • PHP5中GD庫(kù)生成圖形驗(yàn)證碼(有漢字)
  • PHP讀取漢字的點(diǎn)陣數(shù)據(jù)
  • php輸出全部gb2312編碼內(nèi)的漢字方法
  • 在PHP的圖形函數(shù)中顯示漢字

標(biāo)簽:涼山 甘肅 遼陽(yáng) 昭通 梅河口 九江 十堰 韶關(guān)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP切割漢字的常用方法實(shí)例總結(jié)》,本文關(guān)鍵詞  PHP,切割,漢字,的,常用,方法,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP切割漢字的常用方法實(shí)例總結(jié)》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于PHP切割漢字的常用方法實(shí)例總結(jié)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 佛学| 柯坪县| 涟水县| 西青区| 南丹县| 县级市| 平谷区| 浙江省| 文成县| 阿拉善左旗| 洪洞县| 启东市| 拜泉县| 西平县| 文成县| 聂拉木县| 高雄市| 阿拉尔市| 涿鹿县| 乳山市| 涿鹿县| 宁波市| 博兴县| 德格县| 措美县| 任丘市| 永年县| 如皋市| 通化市| 高雄市| 崇文区| 西安市| 榕江县| 四川省| 永福县| 台北市| 浠水县| 靖边县| 襄樊市| 铜梁县| 宜兴市|