У меня есть строка, User name (sales)
и я хочу извлечь текст в скобках, как мне это сделать?
Я подозреваю, что подстрока, но я не могу понять, как читать до закрывающей скобки, длина текста будет меняться.
У меня есть строка, User name (sales)
и я хочу извлечь текст в скобках, как мне это сделать?
Я подозреваю, что подстрока, но я не могу понять, как читать до закрывающей скобки, длина текста будет меняться.
Ответы:
Если вы хотите избежать регулярных выражений, самый простой способ, который я могу придумать:
string input = "User name (sales)";
string output = input.Split('(', ')')[1];
var input = "(fdw) User name (sales) safdsdf (again?)"; var output = input.Split('(', ')').Where((item, index) => index % 2 != 0).ToList();
sales
также из входных строк, содержащих )sales(
, и (sales(
т. д.
Очень простой способ сделать это с помощью регулярных выражений:
Regex.Match("User name (sales)", @"\(([^)]*)\)").Groups[1].Value
В качестве ответа на (очень забавный) комментарий приведем того же Regex с некоторыми пояснениями:
\( # Escaped parenthesis, means "starts with a '(' character"
( # Parentheses in a regex mean "put (capture) the stuff
# in between into the Groups array"
[^)] # Any character that is not a ')' character
* # Zero or more occurrences of the aforementioned "non ')' char"
) # Close the capturing group
\) # "Ends with a ')' character"
var filterRegex = new Regex(Regex.Escape("(") + "([^()]*)" + Regex.Escape(")"));
Предполагая, что у вас есть только одна пара скобок.
string s = "User name (sales)";
int start = s.IndexOf("(") + 1;
int end = s.IndexOf(")", start);
string result = s.Substring(start, end - start);
int end = s.IndexOf(")", start);
. Я
Используйте эту функцию:
public string GetSubstringByString(string a, string b, string c)
{
return c.Substring((c.IndexOf(a) + a.Length), (c.IndexOf(b) - c.IndexOf(a) - a.Length));
}
и вот использование:
GetSubstringByString("(", ")", "User name (sales)")
и результат будет:
sales
Регулярные выражения могут быть лучшим инструментом здесь. Если вы не знакомы с ними, я рекомендую вам установить Expresso - отличный инструмент для регулярных выражений.
Что-то вроде:
Regex regex = new Regex("\\((?<TextInsideBrackets>\\w+)\\)");
string incomingValue = "Username (sales)";
string insideBrackets = null;
Match match = regex.Match(incomingValue);
if(match.Success)
{
insideBrackets = match.Groups["TextInsideBrackets"].Value;
}
string input = "User name (sales)";
string output = input.Substring(input.IndexOf('(') + 1, input.IndexOf(')') - input.IndexOf('(') - 1);
input = "User name (sales(1))
вы можете использовать, input.LastIndexOf(')')
который будет работать, если есть внутренние скобки или нет.
using System;
using System.Text.RegularExpressions;
private IEnumerable<string> GetSubStrings(string input, string start, string end)
{
Regex r = new Regex(Regex.Escape(start) +`"(.*?)"` + Regex.Escape(end));
MatchCollection matches = r.Matches(input);
foreach (Match match in matches)
yield return match.Groups[1].Value;
}
int start = input.IndexOf("(") + 1;
int length = input.IndexOf(")") - start;
output = input.Substring(start, length);
regex
Метод лучше я думаю, но если вы хотите использовать смиренныйsubstring
string input= "my name is (Jayne C)";
int start = input.IndexOf("(");
int stop = input.IndexOf(")");
string output = input.Substring(start+1, stop - start - 1);
или
string input = "my name is (Jayne C)";
string output = input.Substring(input.IndexOf("(") +1, input.IndexOf(")")- input.IndexOf("(")- 1);
Вот читаемая функция общего назначения, которая избегает использования регулярных выражений:
// Returns the text between 'start' and 'end'.
string ExtractBetween(string text, string start, string end)
{
int iStart = text.IndexOf(start);
iStart = (iStart == -1) ? 0 : iStart + start.Length;
int iEnd = text.LastIndexOf(end);
if(iEnd == -1)
{
iEnd = text.Length;
}
int len = iEnd - iStart;
return text.Substring(iStart, len);
}
Чтобы назвать это в вашем конкретном примере, вы можете сделать:
string result = ExtractBetween("User name (sales)", "(", ")");
Я считаю, что регулярные выражения чрезвычайно полезны, но их очень сложно написать. Итак, я провел небольшое исследование и нашел этот инструмент, который делает их написание настолько простым.
Не уклоняйтесь от них, потому что синтаксис трудно понять. Они могут быть такими сильными.
Я сталкивался с этим, когда искал решение для очень похожей реализации.
Вот фрагмент из моего фактического кода. Начинает подстроку с первого символа (индекс 0).
string separator = "\n"; //line terminator
string output;
string input= "HowAreYou?\nLets go there!";
output = input.Substring(0, input.IndexOf(separator));
Этот код быстрее, чем большинство решений здесь (если не все), упакован как метод расширения String , он не поддерживает рекурсивное вложение:
public static string GetNestedString(this string str, char start, char end)
{
int s = -1;
int i = -1;
while (++i < str.Length)
if (str[i] == start)
{
s = i;
break;
}
int e = -1;
while(++i < str.Length)
if (str[i] == end)
{
e = i;
break;
}
if (e > s)
return str.Substring(s + 1, e - s - 1);
return null;
}
Этот немного длиннее и медленнее, но он лучше обрабатывает рекурсивное вложение:
public static string GetNestedString(this string str, char start, char end)
{
int s = -1;
int i = -1;
while (++i < str.Length)
if (str[i] == start)
{
s = i;
break;
}
int e = -1;
int depth = 0;
while (++i < str.Length)
if (str[i] == end)
{
e = i;
if (depth == 0)
break;
else
--depth;
}
else if (str[i] == start)
++depth;
if (e > s)
return str.Substring(s + 1, e - s - 1);
return null;
}