2016-04-15 2 views
0

Я следующее заявление:Regex Match Заявление

(({ dbo.Document.MimeType_ID in (select ID from MimeType where Name ='PDF')} Or { dbo.WorkflowItem.CurrentStateName not like 'On_Hold%'}) And ({ dbo.DocumentMetaData.Field_ID=74 And dbo.DocumentMetaData.FieldValue Not like '%test%'} And { dbo.Document.FileName='karan'})) 

Я хочу 4 заявления между {}

например

dbo.Document.MimeType_ID in (select ID from MimeType where Name ='PDF') 
dbo.WorkflowItem.CurrentStateName not like 'On_Hold%' 
dbo.DocumentMetaData.Field_ID=74 And dbo.DocumentMetaData.FieldValue Not like '%test%' 
dbo.Document.FileName='karan' 
+2

есть вложенные шаблон? Также я предлагаю вам использовать парсер – rock321987

+0

Нет, это не вложенный шаблон, на самом деле его формула предварительного поиска, теперь я хочу восстановить поиск, мое простое требование - как получить все утверждения между {} –

+1

- https://regex101.com/r/tQ9bY6/2 хорошо? – rock321987

ответ

1

Это регулярное выражение будет работать (если нет вложенная структура)

\{\s*([^}]+)\s*\} 

C# Код

string input = "(({ dbo.Document.MimeType_ID in (select ID from MimeType where Name ='PDF')} Or { dbo.WorkflowItem.CurrentStateName not like 'On_Hold%'}) And ({ dbo.DocumentMetaData.Field_ID=74 And dbo.DocumentMetaData.FieldValue Not like '%test%'} And { dbo.Document.FileName='karan'}))"; 
string pattern = "\\{\\s*([^}]+)\\s*\\}"; 
Regex rgx = new Regex(pattern); 

Match match = rgx.Match(input); 

while (match.Success) 
{ 
    Console.WriteLine(match.Groups[1].Value); 
    match = match.NextMatch(); 
} 

Ideone Demo