相关疑难解决方法(0)

从字符串中删除特定unicode范围的字符

我有一个程序正在从twitter流api实时解析推文.在存储它们之前,我将它们编码为utf8.某些字符最终出现在字符串中?,??或??? 而不是他们各自的unicode代码并导致问题.经过进一步调查,我发现有问题的字符来自"表情符号"块,U + 1F600 - U + 1F64F,以及"其他符号和象形文字"块,U + 1F300 - U + 1F5FF.我尝试删除,但是不成功,因为匹配器最终替换了字符串中的几乎每个字符,而不仅仅是我想要的unicode范围.

String utf8tweet = "";
        try {
            byte[] utf8Bytes = status.getText().getBytes("UTF-8");

            utf8tweet = new String(utf8Bytes, "UTF-8");

        } 
        catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
Pattern unicodeOutliers = Pattern.compile("[\\u1f300-\\u1f64f]", Pattern.UNICODE_CASE | Pattern.CANON_EQ | Pattern.CASE_INSENSITIVE);
Matcher unicodeOutlierMatcher = unicodeOutliers.matcher(utf8tweet);
utf8tweet = unicodeOutlierMatcher.replaceAll(" ");
Run Code Online (Sandbox Code Playgroud)

我该怎么做才能删除这些字符?

java regex utf-8

15
推荐指数
3
解决办法
3万
查看次数

如何在JavaScript中将一个表情符号字符转换为Unicode代码点编号?

如何在javascript中将其转换为此1f600

''.charCodeAt(0);  
Run Code Online (Sandbox Code Playgroud)

这将返回Unicode 55357,但如何从中获取1f600

javascript emoji emojione

2
推荐指数
4
解决办法
7720
查看次数

标签 统计

emoji ×1

emojione ×1

java ×1

javascript ×1

regex ×1

utf-8 ×1