2 回答

TA貢獻(xiàn)1873條經(jīng)驗(yàn) 獲得超9個(gè)贊
您可以在數(shù)字模式周圍使用捕獲組并調(diào)用re.FindStringSubmatch
:
package main
import (
"regexp"
"fmt"
)
const str = "Some strings. Price: 100$. Some strings123"
func main() {
re := regexp.MustCompile(`Price:\s*(\d+)`)
match := re.FindStringSubmatch(str)
if match != nil {
fmt.Println(match[1])
} else {
fmt.Println("No match!")
}
}
請注意,這`Price:\s*(\d+)`是一個(gè)原始字符串文字,您不必額外轉(zhuǎn)義形成正則表達(dá)式轉(zhuǎn)義的反斜杠,因此\s*匹配零個(gè)或多個(gè)空格并(\d+)匹配并將 1+ 位數(shù)字捕獲到此模式字符串文字中的第 1 組中。

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超7個(gè)贊
嘗試使用下一個(gè)正則表達(dá)式:
re := regexp.MustCompile(`Price:[[:space:]]([0-9]+)`) matches := re.FindStringSubmatch(str)
唯一的區(qū)別 - 是括號[0-9]
,現(xiàn)在您可以通過以下方式訪問 100 matches[1]
:。
您也可以替換:[[:space:]]
with \s
[0-9]
with\d
這樣您的正則表達(dá)式看起來會更簡單,例如:Price:\s(\d+)
- 2 回答
- 0 關(guān)注
- 185 瀏覽
添加回答
舉報(bào)