繁体   English   中英

在LinQ上使用Regex.Replace

[英]Using Regex.Replace with LinQ

我有一个小插件,可将Unicode字符串转换为非Unicode字符串。 看起来像:

public static class StringHelper
{
    public static string ToNonUnicode(this string source)
    {
        if (!string.IsNullOrEmpty(source))
        {
            source = source.Trim().Replace(".", "");

            #region rule
            IDictionary<string, string> dict = new Dictionary<string, string>
            {
                { @"\-|\,", "" },
                { @"\s{2}", " " },

                { "à|á|ả|ã|ạ|ă|â|ấ|ầ|ẩ|ẫ|ậ|ằ|ẳ|ắ|ẵ|ặ", "a" },
                { "á|à|ả|ã|ạ|â|ă|ấ|ầ|ẩ|ẫ|ậ|ắ|ằ|ẳ|ẵ|ặ", "a" },

                { "À|Á|Ả|Ã|Ạ|Ă|Â|Ầ|Ấ|Ẩ|Ẫ|Ậ|Ằ|Ắ|Ẳ|Ẵ|Ặ", "A" },
                { "Á|À|Ả|Ã|Ạ|Â|Ă|Ấ|Ầ|Ẩ|Ẫ|Ậ|Ắ|Ằ|Ẳ|Ẵ|Ặ", "A" },

                { "ò|ó|ỏ|õ|ọ|ô|ơ|ồ|ố|ổ|ỗ|ộ|ờ|ớ|ở|ỡ|ợ", "o" },
                { "ó|ò|ỏ|õ|ọ|ô|ơ|ố|ồ|ổ|ỗ|ộ|ớ|ờ|ở|ỡ|ợ", "o" },

                { "Ò|Ó|Ỏ|Õ|Ọ|Ô|Ơ|Ồ|Ố|Ổ|Ỗ|Ộ|Ờ|Ớ|Ở|Ỡ|Ợ", "O" },
                { "Ó|Ò|Ỏ|Õ|Ọ|Ô|Ơ|Ố|Ồ|Ổ|Ỗ|Ộ|Ớ|Ờ|Ở|Ỡ|Ợ", "O" },

                { "è|é|ẻ|ẽ|ẹ|ê|ề|ế|ể|ễ|ệ", "e" },
                { "é|è|ẻ|ẽ|ẹ|ê|ế|ề|ể|ễ|ệ", "e" },

                { "È|É|Ẻ|Ẽ|Ẹ|Ê|Ề|Ế|Ể|Ễ|Ệ", "E" },
                { "É|È|Ẻ|Ẽ|Ẹ|Ê|Ế|Ề|Ể|Ễ|Ệ", "E" },

                { "ù|ú|ủ|ũ|ụ|ư|ừ|ứ|ử|ữ|ự", "u" },
                { "ú|ù|ủ|ũ|ụ|ư|ứ|ừ|ử|ữ|ự", "u" },

                { "Ù|Ú|Ủ|Ũ|Ụ|Ư|Ừ|Ứ|Ử|Ữ|Ự", "U" },
                { "Ú|Ù|Ủ|Ũ|Ụ|Ư|Ứ|Ừ|Ử|Ữ|Ự", "U" },

                { "ì|í|ỉ|ĩ|ị|í|ì|ỉ|ĩ|ị", "i" },
                { "Ì|Í|Ỉ|Ĩ|Ị|Í|Ì|Ỉ|Ĩ|Ị", "I" },

                { "ỳ|ý|ỷ|ỹ|ỵ|ý|ỳ|ỷ|ỹ|ỵ", "y" },
                { "Ỳ|Ý|Ỷ|Ỹ|Ỵ|Ý|Ỳ|Ỷ|Ỹ|Ỵ", "Y" },

                { "đ", "d" }, { "Đ", "D" }
            };
            #endregion

            foreach (var d in dict)
            {
                var matches = Regex.Matches(source, d.Key);
                foreach (Match match in matches)
                {
                    source = Regex.Replace(source, match.Value, d.Value);
                }
            }                
        }            
        return source;
    }
}

测试:

string str = "Làm người yêu em nhé baby...";
string res = str.ToNonUnicode(); // "Lam nguoi yeu em nhe baby"

为此,我必须使用两次循环,一次用于匹配,一次用于替换。 我正在寻找另一种方法来更快地编写代码。 我认为使用LinQ是一种方法,但是我不知道要去哪里。

你能给我一些提示吗? 谢谢!

您不需要Matches循环,只需直接使用Regex.Replace

foreach (var d in dict)
{
    source = Regex.Replace(source, d.Key, d.Value);
}   

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM