跳到主要內容

寫一個UTF8的split函式 - PHP版

因為一些原因,所以必須寫一個utf8的split函式,可惜php只有str_split函式,沒有utf8的…。
所以就試寫一個,程式碼如下

<?php
function utf_str_split($utf_str, $split_len = 1){ 
    $len = mb_strlen($utf_str, 'UTF-8'); 
    $arr = array(); 
    $temp_str = $utf_str; 
    for($i = 0 ; $i<$len/$split_len ; $i++){ 
        $arr[] = mb_substr($temp_str, 0, $split_len, 'UTF-8'); 
        $temp_str = mb_substr($temp_str, $split_len, $len, 'UTF-8'); 
    } 
    return $arr; 
}
?>

以下是Joomla 的 utf8_str_split()
原文連結:Source code for file /phputf8/str_split.php


<?php
function 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 <= $split_len) return array($str); 
    preg_match_all('/.{'.$split_len.'}|[^\x00]{1,'.$split_len.'}$/us', $str, $ar); 
    return $ar[0]; 
}
?>


用一個六千多字的字串測試
分割長度是1
utf_str_split:0.712316989899 sec
utf8_str_split:1.12109088898 sec
分割長度是2
utf_str_split:0.525295972824 sec
utf8_str_split:0.536201000214 sec
分割長度是10
utf_str_split:0.109910964966 sec
utf8_str_split:0.109711885452 sec
測試完後,只有分割長度為1的時候比較有明顯差距,但是大於1的效率都差不多了

留言

這個網誌中的熱門文章

判斷是不是json格式 - PHP

<?php /** * Check the string is json * * @param string $str * @return bool * @throws Exception if the string is not json */ function isJson ( $str ) { json_decode ( $str ); $code = json_last_error (); switch ( $code ) { case JSON_ERROR_NONE: return true ; case JSON_ERROR_DEPTH: throw new Exception( "Maximum stack depth exceeded" ); case JSON_ERROR_STATE_MISMATCH: throw new Exception( "Underflow or the modes mismatch" ); case JSON_ERROR_CTRL_CHAR: throw new Exception( "Unexpected control character found" ); case JSON_ERROR_SYNTAX: throw new Exception( "Syntax error, malformed JSON" ); case JSON_ERROR_UTF8: throw new Exception( "Malformed UTF-8 characters, possibly incorrectly encoded" ); default : throw new Exception( "U...

input 陣列 - PHP

要如何在 input 裡面回傳陣列資料呢? 就寫了一個簡單的小範例。 以下是 php 原始碼 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 <?php /** 印出Get裡面的資訊 **/ if ( ! empty ( $_GET )) print_r ( $_GET ); /** 初始資料設定 **/ $id = array ( 0 => '#0001' , 1 => '#0002' ); $data [ $id [ 0 ]] = array ( 'date' => '2012-08-12' , 'note' => '上海出差' ); $data [ $id [ 1 ]] = array ( 'date' => '2012-08-17' , 'note' => '北京出差' ); /** 印出表單資訊 **/ echo "<form method='get'>" ; foreach ( $data as $key => $row ){ echo "<input type='text' name=' { $key } [date]' value=' { $row [ 'date' ] } ' />" ; echo "<input type='text' name=' { $key } [note]' value=' { $row [ 'note' ] } ' />" ; echo "<br />" ; } echo "<input type='submit' value='送出' />" ; e...

MySQL INSERT or UPDATE

有些時候在記錄資料時,總是會需要判斷資料有無存在,在進行資料寫入,或是更新資料。 所以至少都得先進行SELECT再去判斷資料有無存在,不存在就INSERT,存在就進行UPDATE,之前從沒找過有沒有更簡單的方法進行。 這次無意間找資料時,才看到INSERT ... ON DUPLICATE KEY UPDATE ...。 舉個簡單的範例,現在有個TABLE A如下 SQL範例如下 INSERT INTO ` A ` ( ` item_id ` , ` item_count ` , ` count_date ` ) VALUES ( 'SwefcskoWdsl' , 1 , '2013-05-14' ) ON DUPLICATE KEY UPDATE ` item_count ` = ` item_count ` + 1 ; 這段SQL就會依照當item_id與count_date資料不存在,則會新增;否則就會在指定的item_id與count_date的item_count進行+1的動作。 MySQL文件 P.S. 這時發現以前的自己好蠢Orz...