1

我的输入如下,

输入

StatusMsg:
seqId: 14043
timestamp: 140707
dId: "Sa01"
msgType: SEQUENCE
eventType: UPDATE_CMD
devContext {
   context: IDLE
   operationalMode: 1
   logHistory {
      start: 1404387563607
      end: 1404387563616
   }
}
manifest {
   timestamp: 1404387733059
   dev {
      dId: "Sa01"
      mainComponent {
         serialNum: "10001"
         deviceClass: "Sap"
         componentType: "Sa01"
         subcomponentNum: 1
      }
   }
   info {
      name: "Sa01"
      channels: 1
      lib {
         name: "l.bin"
         timestamp: 1404387733059
         version: "6870711ee"
         validStartDate: 1404387733059
      }
      activeSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "12.001"
         validStartDate: 1404387733059
      }
      activeCSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "03.001"
         validStartDate: 1404387733059
      }
   }
}
powerStatus {
   powerEvent: ON
   powerSource: AC
   chargerStatus: CHARGING
   batteryStatus: GOOD
}
status {
   msgHeader {
      messageId: 13
      timestamp: 1404387733059
      seqNum: 13
      sourceId: 13
      numOfParams: 0
   }
   infuserState: READY
   keypadLockout: UNLOCKED
}
cmdResponse {
   cmdType: A_PGM
   aPgm {
      dId: "Sa01"
      refId: 79
      request {
         refId: 79
         libId: "6870711eedb"
         channelId: 1
         lId: 1
         pgmType: FULL
         aPgmType: NEW
         externalId: "EXT_ID_9"
         stats {
            WG: 76230
            HG: 150500
            BS: 1790
         }
         multi: false
      }
      response {
         dId: "Sa01"
         files: 1.bin
         major: 338013710701
         status: Received
      }
   }
}
[2014-07-07 14:10:41.034] I/O Received
StatusMsg:
seqId: 14043
timestamp: 140707
dId: "Sa01"
msgType: SEQUENCE
eventType: UPDATE_CMD
devContext {
   context: IDLE
   operationalMode: 1
   logHistory {
      start: 1404387563607
      end: 1404387563616
   }
}
manifest {
   timestamp: 1404387733059
   dev {
      dId: "Sa01"
      mainComponent {
         serialNum: "10001"
         deviceClass: "Sap"
         componentType: "Sa01"
         subcomponentNum: 1
      }
   }
   info {
      name: "Sa01"
      channels: 1
      lib {
         name: "l.bin"
         timestamp: 1404387733059
         version: "6870711ee"
         validStartDate: 1404387733059
      }
      activeSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "12.001"
         validStartDate: 1404387733059
      }
      activeCSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "03.001"
         validStartDate: 1404387733059
      }
   }
}
powerStatus {
   powerEvent: ON
   powerSource: AC
   chargerStatus: CHARGING
   batteryStatus: GOOD
}
status {
   msgHeader {
      messageId: 13
      timestamp: 1404387733059
      seqNum: 13
      sourceId: 13
      numOfParams: 0
   }
   infuserState: READY
   keypadLockout: UNLOCKED
}
cmdResponse {
   cmdType: A_PGM
   aPgm {
      dId: "Sa01"
      refId: 79
      request {
         refId: 79
         libId: "6870711eedb"
         channelId: 1
         lId: 1
         pgmType: FULL
         aPgmType: NEW
         externalId: "EXT_ID_9"
         stats {
            WG: 76230
            HG: 150500
            BS: 1790
         }
         multi: false
      }
      response {
         dId: "Sa01"
         files: 1.bin
         major: 35723057325
         status: Valid
      }
   }
}
[2014-07-07 14:15:71.028] I/O Received
StatusMsg:
seqId: 14043
timestamp: 140707
dId: "Sa01"
msgType: SEQUENCE
eventType: UPDATE_CMD
devContext {
   context: IDLE
   operationalMode: 1
   logHistory {
      start: 1404387563607
      end: 1404387563616
   }
}
manifest {
   timestamp: 1404387733059
   dev {
      dId: "Sa01"
      mainComponent {
         serialNum: "10001"
         deviceClass: "Sap"
         componentType: "Sa01"
         subcomponentNum: 1
      }
   }
   info {
      name: "Sa01"
      channels: 1
      lib {
         name: "l.bin"
         timestamp: 1404387733059
         version: "6870711ee"
         validStartDate: 1404387733059
      }
      activeSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "12.001"
         validStartDate: 1404387733059
      }
      activeCSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "03.001"
         validStartDate: 1404387733059
      }
   }
}
powerStatus {
   powerEvent: ON
   powerSource: AC
   chargerStatus: CHARGING
   batteryStatus: GOOD
}
status {
   msgHeader {
      messageId: 13
      timestamp: 1404387733059
      seqNum: 13
      sourceId: 13
      numOfParams: 0
   }
   infuserState: READY
   keypadLockout: UNLOCKED
}
cmdResponse {
   cmdType: A_PGM
   aPgm {
      dId: "Sa01"
      refId: 79
      request {
         refId: 79
         libId: "6870711eedb"
         channelId: 1
         lId: 1
         pgmType: FULL
         aPgmType: NEW
         externalId: "EXT_ID_9"
         stats {
            WG: 76230
            HG: 150500
            BS: 1790
         }
         multi: false
      }
      response {
         dId: "Sa01"
         files: 1.bin
         major: 27151510570
         status: Accepted
      }
   }
}
[2014-07-07 14:15:51.034] I/O Received
StatusMsg:
seqId: 14043
timestamp: 140707
dId: "Sa01"
msgType: SEQUENCE
eventType: UPDATE_CMD
devContext {
   context: IDLE
   operationalMode: 1
   logHistory {
      start: 1404387563607
      end: 1404387563616
   }
}
manifest {
   timestamp: 1404387733059
   dev {
      dId: "Sa01"
      mainComponent {
         serialNum: "10001"
         deviceClass: "Sap"
         componentType: "Sa01"
         subcomponentNum: 1
      }
   }
   info {
      name: "Sa01"
      channels: 1
      lib {
         name: "l.bin"
         timestamp: 1404387733059
         version: "6870711ee"
         validStartDate: 1404387733059
      }
      activeSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "12.001"
         validStartDate: 1404387733059
      }
      activeCSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "03.001"
         validStartDate: 1404387733059
      }
   }
}
powerStatus {
   powerEvent: ON
   powerSource: AC
   chargerStatus: CHARGING
   batteryStatus: GOOD
}
status {
   msgHeader {
      messageId: 13
      timestamp: 1404387733059
      seqNum: 13
      sourceId: 13
      numOfParams: 0
   }
   infuserState: READY
   keypadLockout: UNLOCKED
}
cmdResponse {
   cmdType: A_PGM
   aPgm {
      dId: "Sa01"
      refId: 79
      request {
         refId: 79
         libId: "6870711eedb"
         channelId: 1
         lId: 1
         pgmType: FULL
         aPgmType: NEW
         externalId: "EXT_ID_9"
         stats {
            WG: 76230
            HG: 150500
            BS: 1790
         }
         multi: false
      }
      response {
         dId: "Sa01"
         files: 1.bin
         major: 35723057325
         status: Valid
      }
   }
}

我想确保以下内容必须以相同的顺序出现在输入中,

StatusMsg:
dId: "Sa01"
eventType: UPDATE_CMD
cmdResponse
cmdType: A_PGM
response
dId: "Sa01"
status: Accepted

预期产出

StatusMsg:
seqId: 14043
timestamp: 140707
dId: "Sa01"
msgType: SEQUENCE
eventType: UPDATE_CMD
devContext {
   context: IDLE
   operationalMode: 1
   logHistory {
      start: 1404387563607
      end: 1404387563616
   }
}
manifest {
   timestamp: 1404387733059
   dev {
      dId: "Sa01"
      mainComponent {
         serialNum: "10001"
         deviceClass: "Sap"
         componentType: "Sa01"
         subcomponentNum: 1
      }
   }
   info {
      name: "Sa01"
      channels: 1
      lib {
         name: "l.bin"
         timestamp: 1404387733059
         version: "6870711ee"
         validStartDate: 1404387733059
      }
      activeSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "12.001"
         validStartDate: 1404387733059
      }
      activeCSW {
         name: "Sa01"
         timestamp: 1404387733059
         version: "03.001"
         validStartDate: 1404387733059
      }
   }
}
powerStatus {
   powerEvent: ON
   powerSource: AC
   chargerStatus: CHARGING
   batteryStatus: GOOD
}
status {
   msgHeader {
      messageId: 13
      timestamp: 1404387733059
      seqNum: 13
      sourceId: 13
      numOfParams: 0
   }
   infuserState: READY
   keypadLockout: UNLOCKED
}
cmdResponse {
   cmdType: A_PGM
   aPgm {
      dId: "Sa01"
      refId: 79
      request {
         refId: 79
         libId: "6870711eedb"
         channelId: 1
         lId: 1
         pgmType: FULL
         aPgmType: NEW
         externalId: "EXT_ID_9"
         stats {
            WG: 76230
            HG: 150500
            BS: 1790
         }
         multi: false
      }
      response {
         dId: "Sa01"
         files: 1.bin
         major: 27151510570
         status: Accepted
      }
   }
}

我尝试使用正则表达式,

(StatusMsg:.*?dId:\s*"Sa01".*?eventType: UPDATE_CMD.*?response\s*{[\s\n\w\.:]*dId:\s*"Sa01"[\s\n\w\.:]*status:\s*Accepted)

上面的表达式从第一个StatusMsgAccepted进行选择。任何人都可以帮助构建正确的正则表达式吗?

4

1 回答 1

1

你只需要对你的正则表达式做一点小改动就可以做到这一点。请注意,对于您的正则表达式,您还需要最后的m标志。

更新的正则表达式:

/(StatusMsg:(?!.*StatusMsg:).*?dId:\s*"Sa01".*?eventType: UPDATE_CMD.*?response\s*{[\s\n\w\.:]*dId:\s*"Sa01"[\s\n\w\.:]*status:\s*Accepted)/m

注意:要使用 rubular 进行测试,请将/开头和/m结尾的 去掉,然后将 放在m您输入正则表达式的右侧的小文本框中。这会将m标志设置为应用,这会导致.您的正则表达式匹配换行符(不是默认行为)。

唯一改变的是

StatusMsg:.*?

已经成为

StatusMsg:(?!.*StatusMsg:).*?

这适用于负前瞻。这实际上是告诉您的正则表达式仅匹配您的正则表达式匹配的位置,但仅当匹配项不包含两个字符串时StatusMsg

如果StatusMsg总是出现在行首且没有前面的空格,则可以通过以下方式使其更加具体:

^StatusMsg:(?!.*^StatusMsg:).*?

于 2014-07-07T11:13:05.477 回答