C#操作操作类库五(字符串的常用扩展方法)

  • 验证字符串是否由正负号(+-)、数字、小数点构成,并且最多只有一个小数点
  • 验证字符串是否仅由[0-9]构成
  • 验证字符串是否由字母和数字构成
  • 验证是否为空字符串。若无需裁切两端空格,建议直接使用 String.IsNullOrEmpty(string)
  • 裁切字符串(中文按照两个字符计算)
  • 裁切字符串(中文按照两个字符计算,裁切前会先过滤 Html 标签)
  • 过滤HTML标签
  • 获取字符串长度。与string.Length不同的是,该方法将中文作 2 个字符计算。
  • 将形如 10.1MB 格式对用户友好文件大小字符串还原成真实的文件大小,单位为字节
  • 根据文件夹命名规则验证字符串是否符合文件夹格式
  • 根据文件名命名规则验证字符串是否符合文件名格式
  • 验证是否为合法的RGB颜色字符串

 

 

public static class ExtendedString

{

    /// <summary>

    /// 验证字符串是否由正负号(+-)、数字、小数点构成,并且最多只有一个小数点

    /// </summary>

    /// <param name="str"></param>

    /// <returns></returns>

    public static bool IsNumeric(this string str)

    {

        Regex regex = new Regex(@"^[+-]?\d+[.]?\d*$");

        return regex.IsMatch(str);            

    }

 

    /// <summary>

    /// 验证字符串是否仅由[0-9]构成

    /// </summary>

    /// <param name="str"></param>

    /// <returns></returns>

    public static bool IsNumericOnly(this string str)

    {

        Regex regex = new Regex("[0-9]");

        return regex.IsMatch(str);

    }

 

    /// <summary>

    /// 验证字符串是否由字母和数字构成

    /// </summary>

    /// <param name="str"></param>

    /// <returns></returns>

    public static bool IsNumericOrLetters(this string str)

    {

        Regex regex = new Regex("[a-zA-Z0-9]");

        return regex.IsMatch(str);

    }

 

    /// <summary>

    /// 验证是否为空字符串。若无需裁切两端空格,建议直接使用 String.IsNullOrEmpty(string)

    /// </summary>

    /// <param name="str"></param>

    /// <returns></returns>

    /// <remarks>

    /// 不同于String.IsNullOrEmpty(string),此方法会增加一步Trim操作。如 IsNullOrEmptyStr(" ") 将返回 true。

    /// </remarks>

    public static bool IsNullOrEmptyStr(this string str)

    {

        if (string.IsNullOrEmpty(str)) { return true; }

        if (str.Trim().Length == 0) { return true; }

        return false;

    }

 

    /// <summary>

    /// 裁切字符串(中文按照两个字符计算)

    /// </summary>

    /// <param name="str">旧字符串</param>

    /// <param name="len">新字符串长度</param>

    /// <param name="HtmlEnable">为 false 时过滤 Html 标签后再进行裁切,反之则保留 Html 标签。</param>

    /// <remarks>

    /// <para>注意:<ol>

    /// <li>若字符串被截断则会在末尾追加“...”,反之则直接返回原始字符串。</li>

    /// <li>参数 <paramref name="HtmlEnable"/> 为 false 时会先调用<see cref="uoLib.Common.Functions.HtmlFilter"/>过滤掉 Html 标签再进行裁切。</li>

    /// <li>中文按照两个字符计算。若指定长度位置恰好只获取半个中文字符,则会将其补全,如下面的例子:<br/>

    /// <code><![CDATA[

    /// string str = "感谢使用uoLib。";

    /// string A = CutStr(str,4);   // A = "感谢..."

    /// string B = CutStr(str,5);   // B = "感谢使..."

    /// ]]></code></li>

    /// </ol>

    /// </para>

    /// </remarks>

    public static string CutStr(this string str, int len, bool HtmlEnable)

    {

        if (str == null || str.Length == 0 || len <= 0) { return string.Empty; }

 

        if (HtmlEnable == false) str = HtmlFilter(str);

        int l = str.Length;

 

        #region 计算长度

        int clen = 0;//当前长度 

        while (clen < len && clen < l)

        {

            //每遇到一个中文,则将目标长度减一。

            if ((int)str[clen] > 128) { len--; }

            clen++;

        }

        #endregion

 

        if (clen < l)

        {

            return str.Substring(0, clen) + "...";

        }

        else

        {

            return str;

        }

    }

    /// <summary>

    /// 裁切字符串(中文按照两个字符计算,裁切前会先过滤 Html 标签)

    /// </summary>

    /// <param name="str">旧字符串</param>

    /// <param name="len">新字符串长度</param>

    /// <remarks>

    /// <para>注意:<ol>

    /// <li>若字符串被截断则会在末尾追加“...”,反之则直接返回原始字符串。</li>

    /// <li>中文按照两个字符计算。若指定长度位置恰好只获取半个中文字符,则会将其补全,如下面的例子:<br/>

    /// <code><![CDATA[

    /// string str = "感谢使用uoLib模块。";

    /// string A = CutStr(str,4);   // A = "感谢..."

    /// string B = CutStr(str,5);   // B = "感谢使..."

    /// ]]></code></li>

    /// </ol>

    /// </para>

    /// </remarks>

    public static string CutStr(this string str, int len)

    {

        if (IsNullOrEmptyStr(str)) { return string.Empty; }

        else

        {

            return CutStr(str, len, false);

        }

    }

    /// <summary>

    /// 过滤HTML标签

    /// </summary>

    public static string HtmlFilter(this string str)

    {

        if (IsNullOrEmptyStr(str)) { return string.Empty; }

        else

        {

            Regex re = new Regex(RegexPatterns.HtmlTag, RegexOptions.IgnoreCase);

            return re.Replace(str, "");

        }

    }

 

    /// <summary>

    /// 获取字符串长度。与string.Length不同的是,该方法将中文作 2 个字符计算。

    /// </summary>

    /// <param name="str">目标字符串</param>

    /// <returns></returns>

    public static int GetLength(this string str)

    {

        if (str == null || str.Length == 0) { return 0; }

 

        int l = str.Length;

        int realLen = l;

 

        #region 计算长度

        int clen = 0;//当前长度 

        while (clen < l)

        {

            //每遇到一个中文,则将实际长度加一。

            if ((int)str[clen] > 128) { realLen++; }

            clen++;

        }

        #endregion

 

        return realLen;

    }

 

    /// <summary>

    /// 将形如 10.1MB 格式对用户友好的文件大小字符串还原成真实的文件大小,单位为字节。

    /// </summary>

    /// <param name="formatedSize">形如 10.1MB 格式的文件大小字符串</param>

    /// <remarks>

    /// 参见:<see cref="uoLib.Common.Functions.FormatFileSize(long)"/>

    /// </remarks>

    /// <returns></returns>

    public static long GetFileSizeFromString(this string formatedSize)

    {

        if (IsNullOrEmptyStr(formatedSize)) throw new ArgumentNullException("formatedSize");

 

        long size;

        if (long.TryParse(formatedSize, out size)) return size;

 

        //去掉数字分隔符

        formatedSize = formatedSize.Replace(",", "");

 

        Regex re = new Regex(@"^([\d\.]+)((?:TB|GB|MB|KB|Bytes))$");

        if (re.IsMatch(formatedSize))

        {

            MatchCollection mc = re.Matches(formatedSize);

            Match m = mc[0];

            double s = double.Parse(m.Groups[1].Value);

 

            switch (m.Groups[2].Value)

            {

                case "TB":

                    s *= 1099511627776;

                    break;

                case "GB":

                    s *= 1073741824;

                    break;

                case "MB":

                    s *= 1048576;

                    break;

                case "KB":

                    s *= 1024;

                    break;

            }

 

            size = (long)s;

            return size;

        }

 

        throw new ArgumentException("formatedSize");

    }

 

    /// <summary>

    /// 根据文件夹命名规则验证字符串是否符合文件夹格式

    /// </summary>

    public static bool IsFolderName(this string folderName)

    {

        if (IsNullOrEmptyStr(folderName)) { return false; }

        else

        {

            // 不能以 “.” 开头

            folderName = folderName.Trim().ToLower();

 

            // “nul”、“aux”、“con”、“com1”、“lpt1”不能为文件夹/文件的名称

            // 作为文件夹,只需满足名称不为这几个就行。

            switch (folderName)

            {

                case "nul":

                case "aux":

                case "con":

                case "com1":

                case "lpt1":

                    return false;

                default:

                    break;

            }

 

            Regex re = new Regex(RegexPatterns.FolderName, RegexOptions.IgnoreCase);

            return re.IsMatch(folderName);

        }

    }

 

    /// <summary>

    /// 根据文件名命名规则验证字符串是否符合文件名格式

    /// </summary>

    public static bool IsFileName(this string fileName)

    {

        if (IsNullOrEmptyStr(fileName)) { return false; }

        else

        {

            fileName = fileName.Trim().ToLower();

            // 不能以 “.” 开头

            // 作为文件名,第一个“.” 之前不能是“nul”、“aux”、“con”、“com1”、“lpt1”

            if (fileName.StartsWith(".")

                || fileName.StartsWith("nul.")

                || fileName.StartsWith("aux.")

                || fileName.StartsWith("con.")

                || fileName.StartsWith("com1.")

                || fileName.StartsWith("lpt1.")

                ) return false;

 

            Regex re = new Regex(RegexPatterns.FileName, RegexOptions.IgnoreCase);

            return re.IsMatch(fileName);

        }

    }

 

    /// <summary>

    /// 验证是否为合法的RGB颜色字符串

    /// </summary>

    /// <param name="color">RGB颜色,如:#00ccff | #039 | ffffcc</param>

    /// <returns></returns>

    public static bool IsRGBColor(this string color)

    {

        if (IsNullOrEmptyStr(color)) { return false; }

        else

        {

            Regex re = new Regex(RegexPatterns.HtmlColor, RegexOptions.IgnoreCase);

            return re.IsMatch(color);

        }

    }

 

    public static string GetJsSafeStr(this string str)

    {

        if (string.IsNullOrEmpty(str))

            return string.Empty;

 

        return str.Replace("\\", "\\\\").Replace("\"", "\\\"");

    }

}

 

 

时间: 2024-10-01 04:46:17

C#操作操作类库五(字符串的常用扩展方法)的相关文章

WebAPi添加常用扩展方法及思维发散

前言 在WebAPi中我们通常需要得到请求信息中的查询字符串或者请求头中数据再或者是Cookie中的数据,如果需要大量获取,此时我们应该想到封装一个扩展类来添加扩展方法,从而实现简便快捷的获取. WebAPi常用扩展方法 (1)获取所有键值对 /// <summary> /// 获取所有键值 /// </summary> /// <param name="request"></param> /// <returns></

开源Math.NET基础数学类库使用(12)C#随机数扩展方法

原文:[原创]开源Math.NET基础数学类库使用(12)C#随机数扩展方法                本博客所有文章分类的总目录:http://www.cnblogs.com/asxinyu/p/4288836.html 开源Math.NET基础数学类库使用总目录:http://www.cnblogs.com/asxinyu/p/4329737.html 前言 真正意义上的随机数(或者随机事件)在某次产生过程中是按照实验过程中表现的分布概率随机产生的,其结果是不可预测的,是不可见的.而计算

【原创】开源Math.NET基础数学类库使用(12)C#随机数扩展方法

               本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新  开源Math.NET基础数学类库使用总目录:[目录]开源Math.NET基础数学类库使用总目录 前言 真正意义上的随机数(或者随机事件)在某次产生过程中是按照实验过程中表现的分布概率随机产生的,其结果是不可预测的,是不可见的.而计算机中的随机函数是按照一定算法模拟产生的,其结果是确定的,是可见的.我们可以这样认为这个可预见的结果其出现的概率是100%.所以用计算机随机函数所产生的"随机数"

C# byte数组常用扩展浅析

C# byte数组常用扩展是我们编程中经常会碰到的一些实用性很强的操作,那么C# byte数组常用扩展都有哪些呢?下面将列出并用实例演示常用八种情况. C# byte数组常用扩展应用一:转换为十六进制字符串 public static string ToHex(this byte b) { return b.ToString("X2"); } public static string ToHex(this IEnumerable<byte> bytes) { var sb

Query常用DIV操作获取和设置长度宽度的实现方法_jquery

获取或设置div的高度和宽度 方法一:height和width函数(得到的是证书),可以用于获取或设置元素的高度和宽度. val()获取或设置元素的值 方法二:css函数可以用于获取或设置元素的高度和宽度 获取css("width")(得到的是以px结尾的字符串),设置css("width",20px)或css({width:20px,height:20px}) JQuery的链式操作 <!DOCTYPE html PUBLIC "-//W3C//D

js数组常见操作及数组与字符串相互转化实例详解_javascript技巧

本文实例讲述了js数组常见操作及数组与字符串相互转化方法.分享给大家供大家参考,具体如下: 数组与字符串的相互转化 <script type="text/javascript"> var obj="new1abcdefg".replace(/(.)(?=[^$])/g,"$1,").split(","); //字符串转化为数组 var obj2 = "new2abcdefg".split(&qu

Ruby中操作字符串的一些基本方法

  这篇文章主要介绍了Ruby中操作字符串的一些基本方法,包括对字符串的压缩和解压缩等处理,需要的朋友可以参考下 在Ruby中的String对象持有和操纵的任意序列的一个或多个字节,通常表示人类语言的字符表示. 简单的字符串文本括在单引号(单引号字符).引号内的文本的字符串值: ? 1 'This is a simple Ruby string literal' 如果需要内放置一个单引号,单引号的字符串文字,在它前面加上一个反斜杠Ruby解释器不认为终止字符串: ? 1 'Won't you r

word-C# .NET,操作WORD在指定字符串位置插入图片。

问题描述 C# .NET,操作WORD在指定字符串位置插入图片. 我是用这句代码插入的图片: //插入图片 object Anchor = myWord.Application.Selection.Range; bp.Save(bmpPath); myDoc.InlineShapes.AddPicture(bmpPath, ref Nothing, ref Nothing, ref Anchor); Anchor是当前行,我就是想把Anchor变成指定字符串的位置. 或者大神有其他方法也希望能够

Ruby中操作字符串的一些基本方法_ruby专题

 在Ruby中的String对象持有和操纵的任意序列的一个或多个字节,通常表示人类语言的字符表示. 简单的字符串文本括在单引号(单引号字符).引号内的文本的字符串值: 'This is a simple Ruby string literal' 如果需要内放置一个单引号,单引号的字符串文字,在它前面加上一个反斜杠Ruby解释器不认为终止字符串: 'Won\'t you read O\'Reilly\'s book?' 反斜杠也可以转义另一个反斜杠,这样第二个反斜杠本身不是解释为转义字符. 以下是