2012-12-20 1 views
3

등호 주위의 문자열에서 텍스트를 일치 시키려고합니다.
내 정규식은 "((?:\\S+\\s)?\\S*=)(\\S*(?:\\s\\S+)?)"입니다. C#은 이스케이프 처리되지 않은 '\'문자열을 사용하지 않으므로 \\이 있습니다.. NET Regex 문제 또한 .NET 정규식은 다른 규칙 엔진을 사용합니까?

문자열이 "the thing=12 and otherthing = 'thirty'" 인 경우 "this =", "12 and", "otherthing ="및 " 'thirty'"그룹이 반환됩니다.

Regex에서 나쁘다. 다음에 무엇을해야할지 모르겠다.
"thing", "12", "otherthing"및 "thirty"("30"에서 작은 따옴표를 제거한 것) 그룹을 반환하려면이 항목이 필요합니다.

아무도 도와 줄 수 있습니까? C# Regex 파서가 gskinner.com의 구문 분석기와 다른 것 같습니다. 일부 작업은 생각했지만 C#은 아닙니다.

+1

문자열 리터럴 앞에 @ 기호를 사용해보십시오. 예 : @ "my \ S string"그렇게하면 역 슬래시를 벗어날 필요가 없습니다. –

+1

http://regexhero.net/ 보셨나요? 다른 날에 내가 .NET에서 작성한 정규식으로 놀아 보았습니다. – mletterle

+0

그래서 정말로 필요한 것은 문자열을'='과 공백 문자로 나누고'''문자를 제거하는 것입니다. –

답변

1

이 패턴은 = 전에 첫 번째 워드 (비 연속 공간)과 같은 인용 값 또는 최초 워드 걸린다.

@"(?<name>[^ =]+?)\s*=\s*('(?<value>[^']+)'|(?<value>[^\s]+))"

(C#에서, 당신은 큰 따옴표를 이스케이프해야하기 때문에 정규식 등에서 특정 요소를 뽑아 오기 위해 리터럴 문자열 @"\s"를 사용하는 것이 가장 좋습니다 @"\s""" == "\\s\"".) the thing=12 and otherthing = 'thirty'를 들어

var pattern = @"(?<name>[^ =]+?)\s*=\s*('(?<value>[^']+)'|(?<value>[^\s]+))"; 
var s = "the thing=12 and otherthing = 'thirty'"; 
foreach(Match match in Regex.Matches(s, pattern)) 
    Console.WriteLine("{0} = {1}", 
     match.Groups["name"].Value, 
     match.Groups["value"].Value); 

, 그것은 산출 :

thing = 12 
otherthing = thirty 
+0

내가 결정한 사항에 대해 물어볼 수 있습니까? 왜 [[^ \]'이 아니라 [[^ \ s =]'입니까? 그 직후에'+'와'?'를 사용합니다. 내가 말할 수있는 한, '?'는 의미가 없다. 나는 그 "가치"측면을 아직 얻지 못했지만, 나는 왜 당신이 그것을 특정한 방식으로하는지 이해하려고 노력하고 있습니다. –

+0

'?'는 최대 값 대신 최소값을 찾습니다. 그렇지 않으면 일치가 항상 최대입니다. 따라서 문자열에'='가 여러 개있는 경우 (있는 경우)'?'가 없으면 모든 인스턴스가'='의 모든 인스턴스를 포함하여 마지막 인스턴스까지 일치하게됩니다 (일치하지 않을 것입니다 마지막 인스턴스는 여전히 패턴의 나머지 부분과 일치해야하기 때문에). –

0

이것은 String.Split의 직업처럼 들립니다. 정규식이 필요하다고 확신하는 경우 Regex.Split을 사용할 수 있습니다.

+0

그건 사실 일 테지만, 이것은 단지 연습 일 뿐이며 Regex를 배우고 싶습니다. –

2

어쩌면 이렇게 될까요?

string input = "bob = 20 joe=thirty"; 
var regex = new Regex(@"(?<left>[^=]+?)\s+=\s+(?<right>[^\s]+)"); 
foreach(Match match in regex.Matches(input)) 
{ 
    Console.WriteLine("{0} = {1}", 
     match.Groups["left"].Value, 
     match.Groups["right"].Value); 
}