function isEmoji(newName)
local len = string.utf8len(newName)--utf8解码长度
for i = 1, len do
local str = string.utf8sub(newName, i, i)
local byteLen = string.len(str)--编码占多少字节
if byteLen > 3 then--超过三个字节的必须是emoji字符啊
return true
end
if byteLen == 3 then
if string.find(str, "[\226][\132-\173]") or string.find(str, "[\227][\128\138]") then
return true--过滤部分三个字节表示的emoji字符,可能是早期的符号,用的还是三字节,坑。。。这里不保证完全正确,可能会过滤部分中文字。。。
end
end
if byteLen == 1 then
local ox = string.byte(str)
if (33 <= ox and 47 >= ox) or (58 <= ox and 64 >= ox) or (91 <= ox and 96 >= ox) or (123 <= ox and 126 >= ox) or (str == " ") then
return true--过滤ASCII字符中的部分标点,这里排除了空格,用编码来过滤有很好的扩展性,如果是标点可以直接用%p匹配。
end
end
end
return false
end
local len = string.utf8len(newName)--utf8解码长度
for i = 1, len do
local str = string.utf8sub(newName, i, i)
local byteLen = string.len(str)--编码占多少字节
if byteLen > 3 then--超过三个字节的必须是emoji字符啊
return true
end
if byteLen == 3 then
if string.find(str, "[\226][\132-\173]") or string.find(str, "[\227][\128\138]") then
return true--过滤部分三个字节表示的emoji字符,可能是早期的符号,用的还是三字节,坑。。。这里不保证完全正确,可能会过滤部分中文字。。。
end
end
if byteLen == 1 then
local ox = string.byte(str)
if (33 <= ox and 47 >= ox) or (58 <= ox and 64 >= ox) or (91 <= ox and 96 >= ox) or (123 <= ox and 126 >= ox) or (str == " ") then
return true--过滤ASCII字符中的部分标点,这里排除了空格,用编码来过滤有很好的扩展性,如果是标点可以直接用%p匹配。
end
end
end
return false
end