java正則表達式ip-ag真人国际官网
1. java正則表達式
http://blog.pfan.cn/iamben250/34352.html這是我的blog上面的詳細介紹。配中文字元的正則表達式: [\u4e00-\u9fa5]
匹配雙位元組字元(包括漢字在內):[^\x00-\xff]
應用:計算字元串的長度(一個雙位元組字元長度計2,ascii字元計1)
string.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
匹配空行的正則表達式:\n[\s| ]*\r
匹配html標記的正則表達式:/<(.*)>.*<\/\1>|<(.*) \/>/
匹配首尾空格的正則表達式:(^\s*)|(\s*$)
應用:javascript中沒有像vbscript那樣的trim函數,我們就可以利用這個表達式來實現,如下:
string.prototype.trim = function()
{
return this.replace(/(^\s*)|(\s*$)/g, "");
}
利用正則表達式分解和轉換ip地址:
下面是利用正則表達式匹配ip地址,並將ip地址轉換成對應數值的javascript程序:
function ip2v(ip)
{
re=/(\d )\.(\d )\.(\d )\.(\d )/g //匹配ip地址的正則表達式
if(re.test(ip))
{
return regexp.$1*math.pow(255,3)) regexp.$2*math.pow(255,2)) regexp.$3*255 regexp.$4*1
}
else
{
throw new error("not a valid ip address!")
}
}
不過上面的程序如果不用正則表達式,而直接用split函數來分解可能更簡單,程序如下:
var ip="10.100.20.168"
ip=ip.split(".")
alert("ip值是:" (ip[0]*255*255*255 ip[1]*255*255 ip[2]*255 ip[3]*1))
匹配email地址的正則表達式:\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*
匹配網址url的正則表達式:http://([\w-] \.) [\w-] (/[\w- ./?%&=]*)?
利用正則表達式去除字串中重復的字元的演算法程序:[註:此程序不正確,原因見本貼回復]
var s="abacabefgeeii"
var s1=s.replace(/(.).*\1/g,"$1")
var re=new regexp("[" s1 "]","g")
var s2=s.replace(re,"")
alert(s1 s2) //結果為:abcefgi
我原來在csdn上發貼尋求一個表達式來實現去除重復字元的方法,最終沒有找到,這是我能想到的最簡單的實現方法。思路是使用後向引用取出包括重復的字元,再以重復的字元建立第二個表達式,取到不重復的字元,兩者串連。這個方法對於字元順序有要求的字元串可能不適用。
得用正則表達式從url地址中提取文件名的javascript程序,如下結果為page1
s=" http://www.9499.net/page1.htm"
s=s.replace(/(.*\/){0,}([^\.] ).*/ig,"$2")
alert(s)
利用正則表達式限制網頁表單里的文本框輸入內容:
用正則表達式限制只能輸入中文:onkeyup="value=value.replace(/[^\u4e00-\u9fa5]/g,'')" onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^\u4e00-\u9fa5]/g,''))"
用正則表達式限制只能輸入全形字元: onkeyup="value=value.replace(/[^\uff00-\uffff]/g,'')" onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^\uff00-\uffff]/g,''))"
用正則表達式限制只能輸入數字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^\d]/g,''))"
用正則表達式限制只能輸入數字和英文:onkeyup="value=value.replace(/[\w]/g,'') "onbeforepaste="clipboarddata.setdata('text',clipboarddata.getdata('text').replace(/[^\d]/g,''))" 出處:藍色理想
前一段時間寫了2段emeditor的宏,用來統計代碼行數和簡單的規約檢查,稍微整理一下,
下面是從emeditor的q&a的提取的實例:雙引號包含的字元串
strings surrounded by double-quotation marks
「.*?」 [ ]包含的字元串
strings surrounded by [ ]
\[[^\[]*?\] 變數名
variable names
[a-za-z_][a-za-z_0-9]* ip 地址
ip addresses
([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3}) 網頁地址
url
(\s )://([^:/] )(:(\d ))?(/[^#\s]*)(#(\s ))? 各行tab以後的文字列
lines followed by a tab
\t.*$ 平仮名 ひらがな
hiragana
[\x{3041}-\x{309e}] 全形片仮名 全形カタカナ
full-width katakana
[\x{309b}-\x{309c}\x{30a1}-\x{30fe}] 半形仮名 半形カナ
half-width kana
[\x{ff61}-\x{ff9f}] 中日韓 漢字
cjk ideographs
[\x{3400}-\x{9fff}\x{f900}-\x{fa2d}] 中日韓 漢字元號
cjk ideograph marks
[\x{3000}-\x{3037}] 韓國字元
hangul
[\x{1100}-\x{11f9}\x{3131}-\x{318e}\x{ac00}-\x{d7a3}] 行頭插入 //
insert // at start of lines
find: ^
replace with: // 刪除行頭 //
remove // at end of lines
find: ^//
replace: 刪除行後的空白文字(包含空格和製表位 space tab)
remove trailing whitespaces
find: \s ?$
replace with: 將(abc)替換為[abc]
replace (abc) with [abc]
find: \((.*?)\)
replace: \[\1\] 將
替換為
replace
with
find:
replace: 將9/13/2003替換為2003年9月13日
replace 9/13/2003 with 2003.9.13
find: ([0-9]{1,2})/([0-9]{1,2})/([0-9]{2,4})
replace: \3年\1月\2日 將字母a-z替換為大寫字母
uppercase characters from a to z
find: [a-z]
replace: \u\0 首字母大寫
capitalize all words
find: ([a-za-z])([a-za-z]*)
replace: \u\1\l\2
replace:
將9/13/2003替換為2003年9月13日
replace 9/13/2003 with 2003.9.13
find: ([0-9]{1,2})/([0-9]{1,2})/([0-9]{2,4})
replace: \3年\1月\2日 將字母a-z替換為大寫字母
uppercase characters from a to z
find: [a-z]
replace: \u\0 首字母大寫
capitalize all words
find: ([a-za-z])([a-za-z]*)
replace: \u\1\l\2
2. java 判斷是否為內網ip
內網ip是以下面幾個段的ip.用戶可以自己設置.常用的內網ip地址:
10.0.0.0~10.255.255.255
172.16.0.0~172.31.255.255
192.168.0.0~192.168.255.255
----------------------選自網路--------------------------------------------------
由於以上ip段、我們只需要做判斷ip是否屬於以上3個網段就行了
publicbooleanisinner(stringip)
{
stringreg="(10|172|192)\.([0-1][0-9]{0,2}|[2][0-5]{0,2}|[3-9][0-9]{0,1})\.([0-1][0-9]{0,2}|[2][0-5]{0,2}|[3-9][0-9]{0,1})\.([0-1][0-9]{0,2}|[2][0-5]{0,2}|[3-9][0-9]{0,1})";//正則表達式=。=、懶得做文字處理了、
patternp=pattern.compile(reg);
matchermatcher=p.matcher(ip);
returnmatcher.find();
}
3. java編寫正則表達式,判斷給定的是否是一個合法的ip地址怎麼寫
正則表達式匹配ip地址,實際上就是分別判斷每個點直接的數字是否符合規范。\x0d\x0apackage com;\x0d\x0a import java.util.regex.matcher;\x0d\x0a import java.util.regex.pattern; \x0d\x0a public class testregex { \x0d\x0a public static boolean isboolip(string ipaddress){ \x0d\x0a string ip="(2[5][0-5]|2[0-4]\\d|1\\d{2}|\\d{1,2})\\.(25[0-5]|2[0-4]\\d|1\\d{2}|\\d{1,2})\\.(25[0-5]|2[0-4]\\d|1\\d{2}|\\d{1,2})\\.(25[0-5]|2[0-4]\\d|1\\d{2}|\\d{1,2})"; \x0d\x0a pattern pattern = pattern.compile(ip); \x0d\x0a matcher matcher = pattern.matcher(ipaddress); \x0d\x0a return matcher.matches();\x0d\x0a } \x0d\x0a /** * @param args \x0d\x0a */ \x0d\x0a public static void main(string[] args) { \x0d\x0a // todo auto-generated method stub \x0d\x0a string ipaddress1 = "10."; \x0d\x0a string ipaddress2 = "0.0.0.0"; \x0d\x0a string ipaddress3 = "255.255.255.255";\x0d\x0a string ipaddress4 = "192.168.2.1";\x0d\x0a string ipaddress5 = "26445687";\x0d\x0a string ipaddress6 = "nihao"; \x0d\x0a string ipaddress7 = "你好!!"; \x0d\x0a if(isboolip(ipaddress1)){ \x0d\x0a system.out.println("ip正確"); \x0d\x0a }else{ \x0d\x0a system.out.println("ip錯誤"); \x0d\x0a } if(isboolip(ipaddress2)){ \x0d\x0a system.out.println("ip正確"); }else{ \x0d\x0a system.out.println("ip錯誤"); \x0d\x0a } if(isboolip(ipaddress3)){ \x0d\x0a system.out.println("ip正確"); }else{ \x0d\x0a system.out.println("ip錯誤"); \x0d\x0a } \x0d\x0a if(isboolip(ipaddress4)){ \x0d\x0a system.out.println("ip正確"); }else{ \x0d\x0a system.out.println("ip錯誤");
4. java 如何驗證ip地址
可以使用正則表達式驗證ip地址,ip地址分為v4和v6兩個版本,v4為32位,分4段,中間用.隔開,v6為128位,可分為4段32位中間用::隔開。
以下是驗證類詳細代碼:
import java.util.regex.pattern;
/**
* a collection of utilities relating to inetaddresses.
*/
public class inetaddressutils {
public static void main(string[] args){
string addr="192.168.1.2";
system.out.println(isipv4address(addr));
}
private static final pattern ipv4_pattern =
pattern.compile(
"^(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)(\\.(25[0-5]|2[0-4]\\d|[0-1]?\\d?\\d)){3}$");
private static final pattern ipv6_std_pattern =
pattern.compile(
"^(?:[0-9a-fa-f]{1,4}:){7}[0-9a-fa-f]{1,4}$");
private static final pattern ipv6_hex_compressed_pattern =
pattern.compile(
"^((?:[0-9a-fa-f]{1,4}(?::[0-9a-fa-f]{1,4})*)?)::((?:[0-9a-fa-f]{1,4}(?::[0-9a-fa-f]{1,4})*)?)$");
public static boolean isipv4address(final string input) {
return ipv4_pattern.matcher(input).matches();
}
public static boolean isipv6stdaddress(final string input) {
return ipv6_std_pattern.matcher(input).matches();
}
public static boolean isipv6hexcompressedaddress(final string input) {
return ipv6_hex_compressed_pattern.matcher(input).matches();
}
public static boolean isipv6address(final string input) {
return isipv6stdaddress(input) || isipv6hexcompressedaddress(input);
}
}
5. java的正則表達式有什麼作用
所有編程語言均支持正則表達。主要方便檢索數據看情況決定是否使用正則。
6. 求java中正則表達式的例子
一、校驗數字的表達式
1 數字:^[0-9]*$
2 n位的數字:^\d{n}$
3 至少n位的數字:^\d{n,}$
4 m-n位的數字:^\d{m,n}$
5 零和非零開頭的數字:^(0|[1-9][0-9]*)$
6 非零開頭的最多帶兩位小數的數字:^([1-9][0-9]*) (.[0-9]{1,2})?$
7 帶1-2位小數的正數或負數:^(\-)?\d (\.\d{1,2})?$
8 正數、負數、和小數:^(\-|\ )?\d (\.\d )?$
9 有兩位小數的正實數:^[0-9] (.[0-9]{2})?$
10 有1~3位小數的正實數:^[0-9] (.[0-9]{1,3})?$
11 非零的正整數:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\ ?[1-9][0-9]*$
12 非零的負整數:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$
13 非負整數:^\d $ 或 ^[1-9]\d*|0$
14 非正整數:^-[1-9]\d*|0$ 或 ^((-\d )|(0 ))$
15 非負浮點數:^\d (\.\d )?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0 |0$
16 非正浮點數:^((-\d (\.\d )?)|(0 (\.0 )?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0 |0$
17 正浮點數:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*))$
18 負浮點數:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9] \.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9] )|([0-9]*[1-9][0-9]*)))$
19 浮點數:^(-?\d )(\.\d )?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0 |0)$
二、校驗字元的表達式
1 漢字:^[\u4e00-\u9fa5]{0,}$
2 英文和數字:^[a-za-z0-9] $ 或 ^[a-za-z0-9]{4,40}$
3 長度為3-20的所有字元:^.{3,20}$
4 由26個英文字母組成的字元串:^[a-za-z] $
5 由26個大寫英文字母組成的字元串:^[a-z] $
6 由26個小寫英文字母組成的字元串:^[a-z] $
7 由數字和26個英文字母組成的字元串:^[a-za-z0-9] $
8 由數字、26個英文字母或者下劃線組成的字元串:^\w $ 或 ^\w{3,20}$
9 中文、英文、數字包括下劃線:^[\u4e00-\u9fa5a-za-z0-9_] $
10 中文、英文、數字但不包括下劃線等符號:^[\u4e00-\u9fa5a-za-z0-9] $ 或 ^[\u4e00-\u9fa5a-za-z0-9]{2,20}$
11 可以輸入含有^%&',;=?$\"等字元:[^%&',;=?$\x22]
12 禁止輸入含有~的字元:[^~\x22]
三、特殊需求表達式
1 email地址:^\w ([- .]\w )*@\w ([-.]\w )*\.\w ([-.]\w )*$
2 域名:[a-za-z0-9][-a-za-z0-9]{0,62}(/.[a-za-z0-9][-a-za-z0-9]{0,62}) /.?
3 interneturl:[a-za-z] ://[^\s]* 或 ^http://([\w-] \.) [\w-] (/[\w-./?%&=]*)?$
4 手機號碼:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$
5 電話號碼("xxx-xxxxxxx"、"xxxx-xxxxxxxx"、"xxx-xxxxxxx"、"xxx-xxxxxxxx"、"xxxxxxx"和"xxxxxxxx):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
6 國內電話號碼(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
7 身份證號:
15或18位身份證:^\d{15}|\d{18}$
15位身份證:^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$
18位身份證:^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{4}$
8 短身份證號碼(數字、字母x結尾):^([0-9]){7,18}(x|x)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9x]{8,18}?$
9 帳號是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-za-z][a-za-z0-9_]{4,15}$
10 密碼(以字母開頭,長度在6~18之間,只能包含字母、數字和下劃線):^[a-za-z]\w{5,17}$
11 強密碼(必須包含大小寫字母和數字的組合,不能使用特殊字元,長度在8-10之間):^(?=.*\d)(?=.*[a-z])(?=.*[a-z]).{8,10}$
12 日期格式:^\d{4}-\d{1,2}-\d{1,2}
13 一年的12個月(01~09和1~12):^(0?[1-9]|1[0-2])$
14 一個月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
15 錢的輸入格式:
16 1.有四種錢的表示形式我們可以接受:"10000.00" 和 "10,000.00", 和沒有 "分" 的 "10000" 和 "10,000":^[1-9][0-9]*$
17 2.這表示任意一個不以0開頭的數字,但是,這也意味著一個字元"0"不通過,所以我們採用下面的形式:^(0|[1-9][0-9]*)$
18 3.一個0或者一個不以0開頭的數字.我們還可以允許開頭有一個負號:^(0|-?[1-9][0-9]*)$
19 4.這表示一個0或者一個可能為負的開頭不為0的數字.讓用戶以0開頭好了.把負號的也去掉,因為錢總不能是負的吧.下面我們要加的是說明可能的小數部分:^[0-9] (.[0-9] )?$
20 5.必須說明的是,小數點後面至少應該有1位數,所以"10."是不通過的,但是 "10" 和 "10.2" 是通過的:^[0-9] (.[0-9]{2})?$
21 6.這樣我們規定小數點後面必須有兩位,如果你認為太苛刻了,可以這樣:^[0-9] (.[0-9]{1,2})?$
22 7.這樣就允許用戶只寫一位小數.下面我們該考慮數字中的逗號了,我們可以這樣:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
23 8.1到3個數字,後面跟著任意個 逗號 3個數字,逗號成為可選,而不是必須:^([0-9] |[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
24 備註:這就是最終結果了,別忘了" "可以用"*"替代如果你覺得空字元串也可以接受的話(奇怪,為什麼?)最後,別忘了在用函數時去掉去掉那個反斜杠,一般的錯誤都在這里
25 xml文件:^([a-za-z] -?) [a-za-z0-9] \\.[x|x][m|m][l|l]$
26 中文字元的正則表達式:[\u4e00-\u9fa5]
27 雙位元組字元:[^\x00-\xff] (包括漢字在內,可以用來計算字元串的長度(一個雙位元組字元長度計2,ascii字元計1))
28 空白行的正則表達式:\n\s*\r (可以用來刪除空白行)
29 html標記的正則表達式:<(\s*?)[^>]*>.*?|<.*? /> (網上流傳的版本太糟糕,上面這個也僅僅能部分,對於復雜的嵌套標記依舊無能為力)
30 首尾空白字元的正則表達式:^\s*|\s*$或(^\s*)|(\s*$) (可以用來刪除行首行尾的空白字元(包括空格、製表符、換頁符等等),非常有用的表達式)
31 騰訊qq號:[1-9][0-9]{4,} (騰訊qq號從10000開始)
32 中國郵政編碼:[1-9]\d{5}(?!\d) (中國郵政編碼為6位數字)
33 ip地址:\d \.\d \.\d \.\d (提取ip地址時有用)