あなたはstrings.IndexRune
、strings.IndexByte
、strings.Split
、strings.SplitAfter
、strings.FieldsFunc
、url.Parse
、regexp
たり、機能を使用することができます。
最初の最も簡単な方法:
あなたは(コメントを出力して)このようなi := strings.IndexRune(s, '?')
またはその後i := strings.IndexByte(s, '?')
s[:i]
を使用することがあります。
package main
import "fmt"
import "strings"
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
i := strings.IndexByte(s, '?')
if i != -1 {
fmt.Println(s[:i]) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
}
またはあなたが使用することがurl.Parse(s)
(私はこれを使用すると思います):
package main
import "fmt"
import "net/url"
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
url, err := url.Parse(s)
if err == nil {
url.RawQuery = ""
fmt.Println(url.String()) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
}
またはあなたが使用することregexp.MustCompile(".*\\.txt")
:
package main
import "fmt"
import "regexp"
var rgx = regexp.MustCompile(`.*\.txt`)
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
fmt.Println(rgx.FindString(s)) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
またはあなたがsplits := strings.FieldsFunc(s, func(r rune) bool { return r == '?' })
splits[0]
を使用することがあります。
package main
import "fmt"
import "strings"
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
splits := strings.FieldsFunc(s, func(r rune) bool { return r == '?' })
fmt.Println(splits[0]) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
あなたがsplits := strings.Split(s, "?")
splits[0]
を使用することがあります。
package main
import "fmt"
import "strings"
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
splits := strings.Split(s, "?")
fmt.Println(splits[0]) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
あなたがsplits := strings.SplitAfter(s, ".txt")
splits[0]
を使用することがあります。
package main
import "fmt"
import "strings"
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
splits := strings.SplitAfter(s, ".txt")
fmt.Println(splits[0]) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
たりしてもよいですあなたの関数を使用する(ほとんど依存しない方法):
package main
import "fmt"
func left(s string) string {
for i, r := range s {
if r == '?' {
return s[:i]
}
}
return ""
}
func main() {
s := `https://example-1.example.com/a/c482dfad3573acff324c/list.txt?parm1=value,parm2=value,parm3=https://example.com/a?parm1=value,parm2=value`
fmt.Println(left(s)) // https://example-1.example.com/a/c482dfad3573acff324c/list.txt
}
Iだろうと、任意の奇妙なエッジケースを処理するためurl.Parseを使用することをお勧めしますこれは正規表現や分割によって見逃される可能性があります。たとえば、? –
私は、url.Parseが最良のアプローチであることに同意します。リストされたすべてのオプションは '? 'のないURLを処理します。 –