Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/regex/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/postgresql/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Regex 在文本中匹配URL,但方括号内的URL除外_Regex - Fatal编程技术网

Regex 在文本中匹配URL,但方括号内的URL除外

Regex 在文本中匹配URL,但方括号内的URL除外,regex,Regex,我正在尝试创建一个正则表达式,以便在文本中识别URL 可能(可能)的测试用例: http://a.url.com http://a.url.co.uk [http://a.url.com] [http://a.url.co.uk] [http://a.url.com] [http://a.url.co.uk] [http://a.url.com ] [http://a.url.co.uk ] [] [] 此处文本http://a.url.com这里呢 此处文本http://a.url.co.u

我正在尝试创建一个正则表达式,以便在文本中识别URL

可能(可能)的测试用例:

  • http://a.url.com
  • http://a.url.co.uk
  • [http://a.url.com]
  • [http://a.url.co.uk]
  • [http://a.url.com]
  • [http://a.url.co.uk]
  • [http://a.url.com ]
  • [http://a.url.co.uk ]
  • []
  • []
  • 此处文本http://a.url.com这里呢
  • 此处文本http://a.url.co.uk这里呢
  • 此处文本[http://a.url.com]这里呢
  • 此处文本[http://a.url.co.uk]及 这里
  • 此处文本[http://a.url.com]及 这里
  • 此处文本[http://a.url.co.uk]及 这里
  • 此处文本[http://a.url.com ]及 这里
  • 此处文本[http://a.url.co.uk ]及 这里
  • 此处文本[]和 这里
  • 此处文本[]和 这里
只有不带方括号的行应该匹配。只有URL应该匹配,而不是整行。如果不清楚,上面列表中的粗体文本是我希望正则表达式匹配的内容

我计算出的当前正则表达式是:

(^|[^\[ ])(https?://\S+)
只有前两行匹配,我不知道如何使没有方括号的其他行匹配

我使用了组,因为稍后我将用一些HTML替换匹配。但是首先需要让正则表达式正常工作

我一直在使用这个在线工具来帮助我构建和测试正则表达式

这应该有效:

(?<=^[^\[\]]*)(https?://\S+)(?=[^\[\]]*$)

(?您修改的工作正则表达式:

([^\S\]](https?:\/\/[^\]\s]+)[^\S\]]|^(https?:\/\/[^\]\s]+)$)

您还可以使用regex使用负前瞻断言来确保行不包含方括号:

^(?!.*\[.*\]).*(https?://\S+)

谢谢你的回复。我将你的正则表达式粘贴到了在线正则表达式工具中;它匹配正确的行,但它匹配整行。我需要在一个组中只匹配该行中的URL部分,这样我就可以用HTML超链接替换该URL。你可以使用组只获取正则表达式的一部分。谢谢你的回复,但这不是很简单正确。您的正则表达式匹配每行中的所有URL。我只想匹配没有方括号的行上的URL。请参阅问题中的粗体行。胡说:。并阅读我答案中的编辑。谢谢,这有助于生成我需要的正则表达式:(?!.[[])(https?:\/\/\S+)