解決lua中截取字符串(中英文混合)賦值失敗的問題

UTF-8中一個漢字字符佔三個字節,有時候我們截取的字符串中是中英文混合的字符串,在截取的時候可能機會得到我們意想不到的結果,打個比方說: local str = “hello中國” string.sub(str,1,6),這樣子得到的結果就是hello? 這樣的字符串是不能在quick-lua裏面作爲控件的strString()這個方法的,原因就是截取字符串的時候有些漢字截得不全,導致字符串亂碼,就像上面那樣,我這裏的解決方案是,能夠截取一個完整的漢字就截取這個漢字,當有漢字截取不完的時候,就丟棄掉,代碼如下:

function g_stringNum( str,num)
    local str = str or "你忘記傳入字符串了"
    local num = num or 6
    local lenInByte = #str
    local count = 0
    local index = 0
    local flag = false
   if lenInByte == 0 then
       return str
   end
    for i=1,lenInByte do    
        local curByte = string.byte(str, i)
        if curByte>0 and curByte<=127 then        
            flag = true
            index = index + 1
            if index >= num then
                str = string.sub(str,1,index)
               return str
            end 
        else  
            if flag then
                count = 0
                flag = false
            end
            count = count + 1
            index = index + 1
            if (count % 3) == 0 then
                count = 0
            end  
            if index >= num then  
                if count == 0 then
                    str = string.sub(str,1,index)
                    print("g_stringNum"..str)
                    return str
                else
                    str = string.sub(str,1,index-count)
                    print("g_stringNum"..str)
                    return str
                end            
            end
        end
    end
    return str
end


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章