c#判断字符串中是否存在重复两个小写字母组成的子串

2024-12-13 08:54:11
推荐回答(1个)
回答1:

目的:判断字符串是否只有数字和字母组成,防止出现“乱码”,以及判断字符串长度;

主要功能函数:System.Text.RegularExpressions.Regex.IsMatch(strMessage, pattern)

strMessage:要判断的字符串;

pattern:判断的条件;

正则表达式用途:1.测试字符串内的模式。2.替换文本。3.基于模式匹配从字符串中提取子字符串。

正则表达式语法:https://msdn.microsoft.com/zh-cn/library/ae5bf541(VS.80).aspx

[csharp] view plain copy

  • /// 

      

  • /// 判断是否为数字或字母  

  • ///   

  • /// 要判断的字符串  

  • /// 最小长度  

  • /// 最大长度  

  • /// 结果  

  • public bool fnIsDigitOrLetter(string strMessage, int iMinLong, int iMaxLong)  

  • {  

  • bool bResult = false;  

  • //开头匹配一个字母或数字+匹配两个十进制数字+匹配一个字母或数字+匹配两个相同格式的的(-加数字)+已字母或数字结尾  

  • //如:1111-111-1119  

  • //string pattern = @"^[a-zA-Z0-9]\d{2}[a-zA-Z0-9](-\d{3}){2}[A-Za-z0-9]$";  

  • //string pattern = @"^[a-zA-Z0-9]\d{2}$"; //开头以字母或数字,然后后面加两个数字字符  

  • string pattern = @"^[a-zA-Z0-9]*$"; //匹配所有字符都在字母和数字之间  

  • //string pattern = @"^[a-z0-9]*$"; //匹配所有字符都在小写字母和数字之间  

  • //string pattern = @"^[A-Z][0-9]*$"; //以大写字母开头,后面的都是数字  

  • //string pattern = @"^\d{3}-\d{2}$";//匹配 333-22 格式,三个数字加-加两个数字  

  • if (strMessage.Length >= iMinLong && strMessage.Length <= iMaxLong)//判断字符串长度  

  • {  

  • if (System.Text.RegularExpressions.Regex.IsMatch(strMessage, pattern))  

  • {  

  • bResult = true;  

  • }  

  • else  

  • {  

  • bResult = false;  

  • }  

  • }  

  • return bResult;  

  • }  


  • 下面分析我目前用的到一些简单语法:

    string pattern = @"^[a-zA-Z0-9]\d{2}[a-zA-Z0-9](-\d{3}){2}[A-Za-z0-9]$";

    理解:  1. ^[a-zA-Z0-9]:表示是以大小写或者数字开头;

    2. /d{2}:表示两个数字

    3.    {a-zA-Z0-9}:表示两个数字后面加一个大小写或者数字

    4.    (-\d{3}){2}:表示连个重复的 -加上三个数字格式,如:-333-444,-123-456

    5. [A-Za-z0-9]$:表示以大小写或者数字结尾;

    正确形式: 1111-111-1111; 

    [csharp] view plain copy

  • string pattern = @"^[a-zA-Z0-9]*$"; //匹配所有字符都在字母和数字之间  

  • 理解:整个字符串的每个字符都必须为大小写或者数字;