我在这里想要实现的是假设我们有两个示例 URL:
url1 = "http://emy.dod.com/kaskaa/dkaiad/amaa//////////"
url2 = "http://www.example.com/"
如何提取精简的 URL?
url1 = "http://emy.dod.com/kaskaa/dkaiad/amaa"
url2 = "http://http://www.example.com"
Ruby 中的 URI.parse
可以清除某些类型的格式错误的 URL,但在这种情况下无效。
如果我们使用正则表达式,那么 /^(.*)\/$/
会从 url1
中删除一个斜杠 /
并且对于url2
。
有人知道如何处理这种类型的 URL 解析吗?
这里的重点是我不希望我的系统有 http://www.example.com/
和 http://www.example.com
被视为两个不同的 URL。 http://emy.dod.com/kaskaa/dkaiad/amaa////
和 http://emy.dod.com/kaskaa/dkaiad/amaa/也是如此
。
最佳答案
如果您只需要删除 url 字符串末尾的所有斜杠,那么您可以尝试以下正则表达式:
"http://emy.dod.com/kaskaa/dkaiad/amaa//////////".sub(/(\/)+$/,'')
"http://www.example.com/".sub(/(\/)+$/,'')
/(\/)+$/
- 此正则表达式在字符串末尾找到一个或多个斜杠。然后我们用空字符串替换这个匹配项。
希望这对您有所帮助。
关于ruby - 如何从 Ruby 中的 URL 中删除多个尾部斜杠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2765483/