含有漢字,數字,字母,底線的Regex

來源:互聯網
上載者:User

我們往往會在ASP.NET中遇到驗證字元或漢字的問題,在網上搜尋了一些好的例子和解決方案,列出來與大家共用.

驗證漢字,數字,字元其實可以用一個Regex就可以解決.

現貼出一個從網上找到的方法:

此文出處:http://www.cnblogs.com/flashicp/archive/2007/06/13/782355.html

1、一個Regex,只含有漢字、數字、字母、底線不能以底線開頭和結尾:
^(?!_)(?!.*?_$)[a-zA-Z0-9_/u4e00-/u9fa5]+$  其中:
^  與字串開始的地方匹配
(?!_)  不能以_開頭
(?!.*?_$)  不能以_結尾
[a-zA-Z0-9_/u4e00-/u9fa5]+  至少一個漢字、數字、字母、底線
$  與字串結束的地方匹配

放在程式裡前面加@,否則需要//進行轉義 @"^(?!_)(?!.*?_$)[a-zA-Z0-9_/u4e00-/u9fa5]+$"
 (或者:@"^(?!_)/w*(?<!_)$"    或者  @" ^[/u4E00-/u9FA50-9a-zA-Z_]+$ "  )

2、只含有漢字、數字、字母、底線,底線位置不限:
  ^[a-zA-Z0-9_/u4e00-/u9fa5]+$

3、由數字、26個英文字母或者底線組成的字串
^/w+$

4、2~4個漢字
  @"^[/u4E00-/u9FA5]{2,4}$";

5、
^[/w-]+(/.[/w-]+)*@[/w-]+(/.[/w-]+)+$

用:(Abc)+    來分析:  XYZAbcAbcAbcXYZAbcAb

XYZAbcAbcAbcXYZAbcAb

6、
[^/u4E00-/u9FA50-9a-zA-Z_]
34555#5' -->34555#5'

[/u4E00-/u9FA50-9a-zA-Z_]    eiieng_89_   --->   eiieng_89_
_';'eiieng_88&*9_    -->  _';'eiieng_88&*9_
_';'eiieng_88_&*9_  -->  _';'eiieng_88_&*9_

public  bool RegexName(string str)
  {
   bool flag=Regex.IsMatch(str,@"^[a-zA-Z0-9_/u4e00-/u9fa5]+$");
   return  flag;
  }

 Regex   reg=new   Regex("^[a-zA-Z_0-9]+$");  
  if(reg.IsMatch(s))  
  {  
  //符合規則  
  }  
  else  
  {  
  //存在非法字元  
  }

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.