C # Regex сопоставляет слова с пробелом между [duplicate]

Симон Моурир дал этот пример :

object o = null;
DateTime d = (DateTime)o;  // NullReferenceException

, где unboxing преобразование (литье) из object (или из одного из классов System.ValueType или System.Enum или из типа интерфейса) - тип значения (кроме Nullable<>) сам по себе дает NullReferenceException.

В другом направлении конверсия бокса из a Nullable<>, которая имеет HasValue, равную false , на ссылочный тип, может дать ссылку null, которая затем может привести к NullReferenceException. Классический пример:

DateTime? d = null;
var s = d.ToString();  // OK, no exception (no boxing), returns ""
var t = d.GetType();   // Bang! d is boxed, NullReferenceException

Иногда бокс происходит по-другому. Например, с помощью этого не общего метода расширения:

public static void MyExtension(this object x)
{
  x.ToString();
}

следующий код будет проблематичным:

DateTime? d = null;
d.MyExtension();  // Leads to boxing, NullReferenceException occurs inside the body of the called method, not here.

Эти случаи возникают из-за специальных правил, используемых во время выполнения при боксе Nullable<> экземпляров.

51
задан Micah 8 November 2010 в 12:39
поделиться

8 ответов

Попробуйте следующее регулярное выражение:

^Red October$

По умолчанию регулярные выражения чувствительны к регистру. ^ отмечает начало совпадающего текста, а $ - конец.

77
ответ дан Pieter van Ginkel 28 August 2018 в 03:30
поделиться

Вам нужно приложить ваше регулярное выражение в ^ (начало строки) и $ (конец строки):

^Red October$
8
ответ дан Anton Gogolev 28 August 2018 в 03:30
поделиться

Извините, но это немного неясно.

Из того, что я читал, вы хотите сделать простое сравнение строк. Для этого вам не нужно регулярное выражение.

string myTest = "Red October";
bool isMatch = (myTest.ToLower() == "Red October".ToLower());
Console.WriteLine(isMatch);
isMatch = (myTest.ToLower() == "The Hunt for Red October".ToLower());
1
ответ дан Dean Thomas 28 August 2018 в 03:30
поделиться

Согласование всей строки может быть выполнено с помощью ^ и $, как указано в предыдущих ответах.

Чтобы сделать регистр нечувствительным к регистру, вы можете реализовать хак, который включает классы символов. лот классов символов.

^[Rr][Ee][Dd] [Oo][Cc][Tt][Oo][Bb][Ee][Rr]$
0
ответ дан dorukayhan 28 August 2018 в 03:30
поделиться

Как правило, и с настройками по умолчанию привязки ^ и $ являются хорошим способом обеспечения соответствия регулярного выражения целой строке.

Несколько предостережений:

Если у вас есть чередование в вашем регулярном выражении, обязательно добавьте ваше регулярное выражение в группу, не связанную с захватом, перед тем, как окружать ее с помощью ^ и $:

^foo|bar$

, конечно, отличается от

^(?:foo|bar)$

Кроме того, ^ и $ могут принимать другое значение (начало / конец строки вместо начала / конца строки ]), если установлены определенные параметры. В текстовых редакторах, поддерживающих регулярные выражения, обычно это поведение по умолчанию. На некоторых языках, особенно Ruby, это поведение нельзя даже отключить.

Поэтому существует еще один набор якорей, которые гарантированно будут совпадать только в начале / конце всей строки:

\A соответствует в начале строки.

\Z соответствует в конце строки или перед окончательным разрывом строки.

\z соответствует в самом конце строки.

Но не все языки поддерживают эти якоря, особенно JavaScript.

25
ответ дан Tim Pietzcker 28 August 2018 в 03:30
поделиться

Используйте модификаторы ^ и $ для обозначения того, где шаблон регулярного выражения находится относительно начала и конца строки:

Regex.Match("Red October", "^Red October$"); // pass
Regex.Match("The Hunt for Red October", "^Red October$"); // fail
15
ответ дан Tim Robinson 28 August 2018 в 03:30
поделиться

Вы можете сделать это, как этот пример, если я хочу только один раз поймать букву минус a в строке, и ее можно проверить с помощью myRegex.IsMatch ()

^ [^ e] [е] {1} [^ е] $

-1
ответ дан Vincent Roy 28 August 2018 в 03:30
поделиться

Я знаю, что это может быть немного поздно, чтобы ответить на это, но, возможно, это будет полезно для кого-то другого.

Простейший способ:

var someString = "...";
var someRegex = "...";
var match = Regex.Match(someString , someRegex );
if(match.Success && match.Value.Length == someString.Length){
    //pass
} else {
    //fail
}
2
ответ дан Zixav 28 August 2018 в 03:30
поделиться
Другие вопросы по тегам:

Похожие вопросы: