Categorygithub.com/mvdan/xurls
modulepackage
1.1.0
Repository: https://github.com/mvdan/xurls.git
Documentation: pkg.go.dev

# README

xurls

GoDoc Travis

Extract urls from text using regular expressions.

go get -u github.com/mvdan/xurls
import "github.com/mvdan/xurls"

func main() {
	xurls.Relaxed.FindString("Do gophers live in golang.org?")
	// "golang.org"
	xurls.Strict.FindAllString("foo.com is http://foo.com/.", -1)
	// []string{"http://foo.com/"}
}

Relaxed is around five times slower than Strict since it does more work to find the URLs without relying on the scheme:

BenchmarkStrictEmpty-4           1000000              1885 ns/op
BenchmarkStrictSingle-4           200000              8356 ns/op
BenchmarkStrictMany-4             100000             22547 ns/op
BenchmarkRelaxedEmpty-4           200000              7284 ns/op
BenchmarkRelaxedSingle-4           30000             58557 ns/op
BenchmarkRelaxedMany-4             10000            130251 ns/op

cmd/xurls

go get -u github.com/mvdan/xurls/cmd/xurls
$ echo "Do gophers live in http://golang.org?" | xurls
http://golang.org

# Packages

# Functions

StrictMatchingScheme produces a regexp that matches urls like Strict but whose scheme matches the given regular expression.

# Variables

PseudoTLDs is a sorted list of some widely used unofficial TLDs.
Relaxed matches all the urls it can find.
SchemesNoAuthority is a sorted list of some well-known url schemes that are followed by ":" instead of "://".
Strict only matches urls with a scheme to avoid false positives.
TLDs is a sorted list of all public top-level domains.