Posted by: ameliorate 2006-07-12 11:37 | ||||
輸出: mb_split()要用到正則,偶正則不熟 :(
|
Posted by: Dalamar 2006-07-12 11:46 |
算ascii碼,超過127的,前或者后多給一位 |
Posted by: ameliorate 2006-07-12 11:48 | ||
沒有更方便的辦法嗎? |
Posted by: aDang 2006-07-12 13:43 |
mb_ 開頭的一串函數(shù) 很好用 |
Posted by: ameliorate 2006-07-12 14:54 | ||
不要這么籠統(tǒng)啊。PHP手冊(cè)中的 mb_* 函數(shù)我都看過啦,沒有類似 str_split() 功能的函數(shù)。 如果依托 mb_strcut() 寫一個(gè) mb_str_split(),要考慮到好多細(xì)節(jié)問題。 過程如下(每次截取36字節(jié),每個(gè)漢字為2字節(jié)): 1、截取由位置 0 起始的 36 個(gè)字節(jié); 2、考慮截取 36 個(gè)字節(jié)后,下一個(gè)起始位置是 35 還是 36(也就是說,第一次實(shí)際上截取了35個(gè)字節(jié)還是36個(gè)字節(jié))? 3、考慮到每次實(shí)際截取的字節(jié)數(shù)可能不是 36 的整數(shù)倍,那么究竟應(yīng)截取多少次(ceil($string_length/$split_length)是不可靠的)? 4、如果用ASCII碼>127也有部分生僻字會(huì)出現(xiàn)問題。 5、擴(kuò)展為 UTF-8 編碼,還要考慮每個(gè)漢字是3個(gè)字節(jié)。 |
Posted by: nio 2006-07-12 15:36 | ||||
看來你還是沒有仔細(xì)看,有個(gè) mb_substr() 的函數(shù)也許對(duì)你有幫助 |
Posted by: ameliorate 2006-07-12 15:37 | ||
已解決。
|
Posted by: aDang 2006-07-12 15:45 |
在MBString庫里面,不用去關(guān)心字節(jié)的問題 mb_strimwidth() 截取你想要的寬度,比如40個(gè)半角英文的寬度 mb_strlen() 計(jì)算一下截出來了多少個(gè)字符 mb_substr() 從原字符串里面把截出來的字符刪掉 設(shè)置好了字符集,mb函數(shù)操作的一切,都是整個(gè)字符,比如‘a(chǎn)‘是一個(gè)字符,‘中‘也是一個(gè)字符 不需要自己去計(jì)算什么編碼方式下多少個(gè)字節(jié)表示一個(gè)字符 |
Posted by: ameliorate 2006-07-12 15:53 |
感謝 aDang、Dalamar、nio 的熱心幫助(按拼音字母排序, )。 |
聯(lián)系客服