当前位置: 首页 > 知识库问答 >
问题:

正则表达式 - LUA正则如何匹配多个段的数字?

邰昀
2023-05-15

由于lua不能使用|、{}等匹配方式,请问gmatch如何能实现(1[1-5]|2[1-3]|3[1-7]|4[1-6]|5[0-4]|6[1-5]|8[1-3])这样的匹配规则?

共有1个答案

易英奕
2023-05-15
local function match_numbers(input)
    local patterns = {
        "1[1-5]",
        "2[1-3]",
        "3[1-7]",
        "4[1-6]",
        "5[0-4]",
        "6[1-5]",
        "8[1-3]",
    }

    local result = {}
    for _, pattern in ipairs(patterns) do
        for number in input:gmatch(pattern) do
            table.insert(result, number)
        end
    end

    return result
end

local input = "11 12 21 31 41 50 61 83 84"
local numbers = match_numbers(input)

for _, number in ipairs(numbers) do
    print(number)
end
 类似资料:
  • 正则表达式如何匹配出这个字符串'calc(100vh - 420px)'中的数字420

  • 有没有人试图描述与正则表达式匹配的正则表达式? 由于重复的关键字,这个主题几乎不可能在网上找到。 它可能在实际应用程序中不可用,因为支持正则表达式的语言通常具有解析它们的方法,我们可以将其用于验证,以及一种在代码中分隔正则表达式的方法,可用于搜索目的。 但是我仍然想知道匹配所有正则表达式的正则表达式是什么样子的。应该可以写一个。

  • 给定下面的字符串 [NeMo(PROD)]10.10.100.100(EFA-B-3)[博科FC-Switch]传感器:电源#1(SNMP自定义表)关闭(无此名称(SNMP错误#2)) 我尝试获取多个匹配项以提取以下值: 因为我是正则表达式的初学者,所以我试图定义一些“规则”: 提取第一个圆括号内的第一个值,例如PROD 提取第一个闭合方括号和第二个开口圆括号之间的值,例如10.10.100.10

  • 问题内容: 我正在使用模块中的函数来匹配某些东西,并且一切正常。 现在,我需要找出我有多少场比赛。是否可以不两次遍历迭代器?(先找出计数然后是真正的迭代) 一些代码: 一切正常,我只需要在循环之前获取匹配数即可。 问题答案: 如果您知道需要所有匹配项,则可以使用该功能。它将返回所有匹配项的列表。然后,您可以只进行匹配次数。

  • 我们得到了一些这样的内容:

  • 主要内容:基本模式匹配,字符簇,确定重复出现基本模式匹配 一切从最基本的开始。模式,是正则表达式最基本的元素,它们是一组描述字符串特征的字符。模式可以很简单,由普通的字符串组成,也可以非常复杂,往往用特殊的字符表示一个范围内的字符、重复出现,或表示上下文。例如: 这个模式包含一个特殊的字符 ^,表示该模式只匹配那些以 once 开头的字符串。例如该模式与字符串 "once upon a time" 匹配,与 "There once was