每行多个令牌的Hubot匹配?

时间:2015-06-05 18:18:14

标签: coffeescript hubot

如何在单个邮件中匹配多次出现的令牌。

module.exports = (robot) ->
  robot.hear /ITEM=(\d+)/, (msg) ->
    msg.send 'matched='+msg.match

我希望能够匹配:

blah blah blah ITEM=100 ITEM=200 ITEM=300 blah blah

但是我只得到上面代码的第一场比赛:

match = blah blah blah ITEM = 100 ITEM = 200 ITEM = 300 blah blah,ITEM = 100

我总是可以只接收消息并手动解析每个项目的每一行,但似乎使用robot.hear应该能够做到。

2 个答案:

答案 0 :(得分:1)

使用两步法,但你可以做一些事情来使它更简洁:

coffee> input = "blah blah blah ITEM=100 ITEM=200 ITEM=300 blah blah"
'blah blah blah ITEM=100 ITEM=200 ITEM=300 blah blah'
coffee> match = input.match /blah blah blah ((ITEM=\d+\s*)+) blah blah$/
[ 'blah blah blah ITEM=100 ITEM=200 ITEM=300 blah blah',
  'ITEM=100 ITEM=200 ITEM=300',
  'ITEM=300',
  index: 0,
  input: 'blah blah blah ITEM=100 ITEM=200 ITEM=300 blah blah' ]
coffee> match[1].match /(ITEM=\d+)/g
[ 'ITEM=100',
  'ITEM=200',
  'ITEM=300' ]

答案 1 :(得分:1)

您可以使用传递给g的正则表达式上的hear标记来避免中间匹配。例如:

module.exports = (robot) -> robot.hear /ITEM=(\d+)/g, (msg) -> msg.send 'matched='+msg.match.join(',')

然后在msg.match中提供所有匹配。