Python正则匹配出一个完整的URL

URL如果考虑可以用所有Unicode字符的话,那就只有空格能判断结尾了,请问这样的话怎么在一段文本中完整提取一个URL,不多不少

"http://www.w3schools.com/学习HTML技术,做一个有趣的网站"

比如上面这个例子,没有空格,是不是没办法提取只提取前面那部分了?

补充:

当然上面只是个例子,希望是能通用一点,貌似做不到吧?

折衷一点也就是提取到 .com/这一类域名这儿了吧?

是不是没办法判断一个完整的URL?

阅读 14.4k
2 个回答
  • 不知道题主是不是仅仅指的是这个网址?如果是这个网址,可以匹配以'http'开头,‘/’结尾的部分。

  • 个人认为题主想表达的意思是一般情况下(结尾没有特殊字符‘/’)如何区分?
    我想可以匹配结尾可以用字母数字 或 特定的后缀com/cn解决(此方法要枚举不能完全覆盖到)

楼主没有描述清楚,到底想要什么样的url~
如果只想要非中文的那部分,可以这样写:
'https?://[^/]+?/'


楼主,你要知道,URL是可以包含中文字符的,你给的例子:
http://www.w3schools.com/学习HTML技术,做一个有趣的网站
完全可以作为一个URL。
所以,你还是没描述清楚你想要什么?

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题