查找代码中的中文

  上周的需求要发繁体版,用繁体中文替换简体中文,本来想直接转换,但是对方提出很多简体、繁体之间表达方式不同,因此需要批量替换。

  尽管前期规划过海外版本,但是最后规范管理不够严格,还是有很多界面上的文字是在代码中写死的。

  因此需要开发一个检索代码中中文的工具。

  代码给UILabel赋值,必然是uilabel.text = "简体中文";因此检查一行代码中双引号的内容是否有中文,即可完成需求。

  需要注意的是编码格式,默认是UTF-8(带签名)。

  上代码:

 [MenuItem("Assets/misc/批量统计脚本中的中文")]
    public static void 批量统计脚本中的中文()
    {
        EditorUtility.DisplayProgressBar("处理中 请稍等", "请勿操作", 0);

        string list = "\n**********中文列表从这里开始**********\n";//中文列表
        string infoList = "\n**********详细列表从这里开始**********\n";//带脚本名字行号的列表
        var gameObjects = Selection.GetFiltered(typeof(Object), SelectionMode.DeepAssets);
        for (int i = 0; i < gameObjects.Length; i++)
        {
            EditorUtility.DisplayProgressBar("处理中 请稍等", "正在处理:" + gameObjects[i].name, (i + 1f) / gameObjects.Length);
            string path = AssetDatabase.GetAssetPath(gameObjects[i]);
            if (!path.Contains(".cs") || path.Contains("Editor"))//过滤非cs代码和editor脚本
            {
                continue;
            }
            string[] scriptsLinelist = File.ReadAllLines(path);
            for (int k = 0; k < scriptsLinelist.Length; k++)
            {
                if ( scriptsLinelist[k].Contains("Debug."))//过滤debug中的中文
                {
                    continue;
                }
                char[] ch = scriptsLinelist[k].ToCharArray();
                bool isStart = false;
                bool ishaveChiese = false;
                string info = "";
                bool isContinue = false;
                for (int j = 0; j < ch.Length; j++)
                {
                    if (j+1<ch.Length&&ch[j] == ‘/‘&&ch[j+1] == ‘/‘)//过滤注释中的中文
                    {
                        isContinue = true;
                        continue;
                    }
                    if (ch[j] == ‘"‘)
                    {
                        isStart = !isStart;
                        if (!isStart)
                        {
                            if (ishaveChiese)
                            {
                                if (isContinue)
                                {
                                    list += "\n";
                                    infoList += "\n";
                                }
                                else
                                {
                                    list += "{0}\n".EFormat(info);
                                    infoList += "路径:{0},行号:{1},中文内容:{2}。\n".EFormat(path, k + 1, info);
                                }
                            }
                            info = "";
                            ishaveChiese = false;
                        }
                    }
                    else
                    {
                        if (isStart)
                        {
                            info += "{0}".EFormat(ch[j]);
                            if (isChinese(ch[j]))
                            {
                                ishaveChiese = true;
                            }
                        }
                    }
                }
            }
        }
        list += "\n**********中文列表到这里结束**********\n";
        infoList += "\n**********详细列表到这里结束**********\n";
        EDebug.LogWarning(list);//打印纯中文列表
        EDebug.LogWarning(infoList);//带详细信息列表
        EditorUtility.ClearProgressBar();
    }
时间: 2024-08-28 16:38:59

查找代码中的中文的相关文章

通过VS2010性能分析来查找代码中那些地方最损耗资源

在编写完成一个程序后,大家都比较关心程序的性能如何,想把程序优化得更好.很多时候凭个人直觉来优化程序是件非常不靠普的事情,即使你是一个优秀的开人员也很难准确地判断程序中那些出现问题.VS2010提供了性能分析工具就能轻松地帮我们解决这一事情. 假设现在写了一个组件,很想知道组件和代码的性能情况.这个可以简单地写一个测试程序. 测试程序写好后可以通过VS2010分析菜单里选择启用性能向导 选择CPU采样后就选择需要分析的项目 测试项目选择完成后就可以运行分析,结束分析后VS2010会提供个详细报告

如何设置可以避免php代码中的中文在浏览器中成为乱码?

其实很简单,只需要在代码开始的前面加上一条这样的语句就行: header("content-Type: text/html; charset=Utf-8");   //设置字符的编码是utp-8mysql_query('set names utf8'); 如果是在html代码中,只需要加上 <Meta http-equiv="Content-Type" Content="text/html; Charset=utf-8">

使用Xcode查找项目中的中文字符串

郝萌主倾心贡献,尊重作者的劳动成果,请勿转载. 如果文章对您有所帮助,欢迎给作者捐赠,支持郝萌主,捐赠数额随意,重在心意^_^ 我要捐赠: 点击捐赠 Cocos2d-X源码下载:点我传送 游戏官方下载:http://dwz.cn/RwTjl 游戏视频预览:http://dwz.cn/RzHHd 游戏开发博客:http://dwz.cn/RzJzI 游戏源码传送:http://dwz.cn/Nret1 项目刚启动的时候 我们一般为了快速开发,会在使用字符串的时候直接选择硬编码到代码中. 比如: s

查找文件中的中文并替换,以支持程序中英文(国际化)

手头的项目需要国际化,一种常用的实现方式是搞两个语言文件,KEY-VALUE形式.Ini文件是常用的key-value实现. 比如 chinese_file.ini           ID_LOGIN_SUCCESS = 成功 english_file.ini            ID_LOGIN_SUCCESS= success 程序启动时,使用其中的某种文件,并加载到hashmap中.程序使用到多语言的地方使用GetTrueText(KEY) . 这样无论哪国的语言,程序里面只有看到的k

Python脚本自动提取和替换代码中的中文

# -*- coding: utf-8 -*- import os import os.path import re import sys reload(sys) sys.setdefaultencoding( "utf-8" ) root_path = os.getcwd()+ os.sep list_name = "" str_list = [] # full path def check_file(file): dic = os.path.splitext(f

android studio 中查找代码中的硬编码

在Android Studio中同时按下Ctrl + Shift+ F  或者其他自定义的快捷键,打开全局搜索,在全局搜索中输入 ^((?!(\*|//)).)+[\u4e00-\u9fa5] 并打勾搜索框的Regular Expression(正则表达式),然后开始搜索,就会找出程序所有的硬编码了. 参考:http://blog.csdn.net/linhh90/article/details/50586833

COCOS2DX 代码中加入中文乱码简单解决办法

void WStrToUTF8(std::string& dest, const std::wstring& src){ dest.clear(); for (size_t i = 0; i < src.size(); i++){ wchar_t w = src[i]; if (w <= 0x7f) dest.push_back((char)w); else if (w <= 0x7ff) { dest.push_back(0xc0 | ((w >> 6)&a

查找文件中除了注释以外的中文

在一些需要国际化的项目中,需要找出曾经代码中的中文替换为其他文字,我这里提供一种比较粗糙的查找小工具check_zh.py.有能改进的地方请大家指出. 环境是linux,python2.6 代码如下: 1 #/usr/bin/env python 2 #coding:utf-8 3 4 import os,sys 5 import re 6 import codecs 7 reload(sys) 8 sys.setdefaultencoding('utf8') 9 10 11 zhPattern

C#查找列表中所有重复出现元素代码

C#查找列表中所有重复出现元素代码 public T[] GetDuplicates(T inputValue) {   List<T> duplicates = new List<T>( );   for (int i = 0; i < this.Count; i++)   {     if (this[i].Equals(inputValue))     {       duplicates.Add(this[i]);     }   }//codego.net   re