2014-09-02 621 views
0

如何考慮感嘆號作爲URL的一部分,正則表達式URL的一部分如何考慮感嘆號爲正則表達式

例子: 的oreginal網址是:BLA1 bla2 http://www.peckale.com/#!contact/c11m6 bla3 我需要找到的網址:http://www.peckale.com/#!contact/c11m6

用正則表達式。

我使用experation:

((www\.|(http|https|ftp|news|file)+\:\/\/)?[&#95;.a-zA-Z0-9-]+\.[a-zA-Z0-9\/&#95;:@=.+?,##%&~-]*[^.|\'|\# |!|\(|?|,| |>|<|;|\)]*) 

但結果是: 切網址#後

問候 沙哈爾

+0

http://stackoverflow.com/questions/161738/what-is-the-best-regular-expression-to-check-if-a-string-is -a化有效網址 – 2014-09-02 08:56:09

回答

0

如果你想匹配的一個URL全文,使用此:

(?:www\.|(?:https?|ftp|news|file):\/\/)[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|] 

是awar e最終字符類確保如果URL是某些文本的一部分,則在URL之後的標點(例如逗號或句號)不被解釋爲URL的一部分。這就像感嘆號(!)符號只採取了他們在URL的中間,但如果它在URL

見演示結束它不會匹配它...

http://regex101.com/r/uG0mD2/3

0

剛剛從過去的否定字符類[^.|\'|\# |!|\(|?|,| |>|<|;|\)]刪除!

((www\.|(http|https|ftp|news|file)+\:\/\/)?[&#95;.a-zA-Z0-9-]+\.[a-zA-Z0-9\/&#95;:@=.+?,##%&~-]*[^.|\'|\#|\(|?|,| |>|<|;|\)]*) 

DEMO

而我的建議是,你並不需要包括字符類中的|符號。

所以這[^.|\'|\#|\(|?|,| |>|<|;|\)]原來是[^.'#\(?, ><;\)]