i, j = string.find("the number 1298 is even", "%d+")
print(i,j)
在上面的代码中,如果我使用%d+
,我会得到12,15
预期的结果,但是使用%d*
,它会返回1,0
。两者之间的唯一区别是它也*
接受 0 值但+
接受 1 或更多。但是为什么又回来了1,0
?
i, j = string.find("the number 1298 is even", "%d+")
print(i,j)
在上面的代码中,如果我使用%d+
,我会得到12,15
预期的结果,但是使用%d*
,它会返回1,0
。两者之间的唯一区别是它也*
接受 0 值但+
接受 1 或更多。但是为什么又回来了1,0
?
首先,该模式%d+
匹配一个或多个数字,并%d*
匹配零个或多个数字,因此在您的示例中,%d+
匹配"1298"
, while%d*
匹配开头的空字符串。零次出现的数字可以通过 匹配,这就是和%d*
之间的区别。+
*
其次,空字符串的索引1
和0
对于空字符串似乎有点奇怪,但它是有道理的。索引1
表示字符串的开始,但是对于空字符串的结束索引,你不能有1
,因为它意味着匹配是第一个字符"t"
,所以它必须小于开始索引,0
就是你得到的那个。
此外, 的返回值string.find()
可以用作string.sub()
获取找到的子字符串的参数。在调用string.sub (s, i, j)
中,如果i
大于j
,则返回一个空字符串。