zoukankan      html  css  js  c++  java
  • java 中文与unicode互转

    public class FontUtil {
    
        public static void main(String[] args) {
            System.out.println(chinaToUnicode("未登陆!"));
            System.out.println(decodeUnicode("u672au767bu9646uff01"));
        }
        
         /** 
         * 把中文转成Unicode码 
         *  
         * @param str 
         * @return 
         */  
        public static String chinaToUnicode(String str) {  
            String result = "";  
            for (int i = 0; i < str.length(); i++) {  
                int chr1 = (char) str.charAt(i);  
                if (chr1 >= 19968 && chr1 <= 171941) {// 汉字范围 u4e00-u9fa5 (中文)  
                    result += "\u" + Integer.toHexString(chr1);  
                } else {  
                    result += str.charAt(i);  
                }  
            }  
            return result;  
        }  
      
        /** 
         * 判断是否为中文字符 
         *  
         * @param c 
         * @return 
         */  
        public static boolean isChinese(char c) {  
            Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);  
            if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS  
                    || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS  
                    || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A  
                    || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION  
                    || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION  
                    || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) {  
                return true;  
            }  
            return false;  
        }  
        
        
        //Unicode转中文  
        public static String decodeUnicode(final String unicode) {     
             StringBuffer string = new StringBuffer();  
             
             String[] hex = unicode.split("\\u");  
       
             for (int i = 0; i < hex.length; i++) {  
                   
                 try {  
                     // 汉字范围 u4e00-u9fa5 (中文)  
                     if(hex[i].length()>=4){//取前四个,判断是否是汉字  
                         String chinese = hex[i].substring(0, 4);  
                         try {  
                             int chr = Integer.parseInt(chinese, 16);  
                             boolean isChinese = isChinese((char) chr);  
                             //转化成功,判断是否在  汉字范围内  
                             if (isChinese){//在汉字范围内  
                                 // 追加成string  
                                 string.append((char) chr);  
                                 //并且追加  后面的字符  
                                 String behindString = hex[i].substring(4);  
                                 string.append(behindString);  
                             }else {  
                                 string.append(hex[i]);  
                             }  
                         } catch (NumberFormatException e1) {  
                             string.append(hex[i]);  
                         }  
                           
                     }else{  
                         string.append(hex[i]);  
                     }  
                 } catch (NumberFormatException e) {  
                     string.append(hex[i]);  
                 }  
             }  
       
             return string.toString();  
        }  
        
    }
  • 相关阅读:
    iOS开发之使用 infer静态代码扫描工具
    iOS 组件化开发之使用CocoaPod制作自己的远程私有库
    WKWebView 使用的坑
    iOS 自动化打包发布(Fastlane+ Jenkins+蒲公英)
    Flutter 开发入门实践
    【读书笔记】--《编写高质量iOS与OS X代码的52个有效方法》
    iOS 10.3+ 动态修改 App 图标
    ubuntu16.04 安装 caffe cuda 相关流程
    ubuntu 休眠后窗口边缘出现花边的解决方案
    c++实现二叉树的非递归创建以及非递归先序、中序、后序遍历
  • 原文地址:https://www.cnblogs.com/shihaiming/p/9089904.html
Copyright © 2011-2022 走看看