假设我们有一个名为source的字符串。它包含"纽约市 - 12A - 1234B"
以下是规则:
一个。我们知道字符串开头最近的两个数字应该与下面的字符一起保存,并放在一个单独的字符串中,称为结果;
湾我们不确定这个后面的字符是数字还是字母
℃。字符串本身的格式也各不相同 - 可能是" NY 12A 1234B"
d。我们可以少关心其他任何事情!
现在我凭借无限的智慧制造了这种怪物。它可以工作,但请告诉我有更好的方法来做到这一点,或者充其量是一种更清晰,更注重表现的方式。
class Program
{
public static int i = 0;
public static int q = 0;
public static int x = 0;
public static string source = "New York City - 12A - 1234B";
public static string results = "";
public static char[] from_source_char;
public static List<string> from_source_list = new List<string>();
static void Main(string[] args)
{
from_source_char = source.ToCharArray();
foreach (char unit in from_source_char)
{
from_source_list.Add(unit.ToString());
}
Console.WriteLine("Doing while " + i.ToString() + " < " + (from_source_list.Count() - 1).ToString());
while (i < from_source_list.Count() - 1)
{
Console.WriteLine("i is at " + i.ToString());
Console.WriteLine("Examining " + from_source_list[i].ToString());
try
{
q = Convert.ToInt32(from_source_list[i]);
results += from_source_list[i].ToString();
Console.WriteLine("Found part 1!");
x++;
}
catch
{
Console.WriteLine("Disregarding " + from_source_list[i].ToString());
// do nothing
}
if (x == 2)
{
Console.WriteLine("Found final part! " + from_source_char[i+1].ToString());
results += from_source_char[i+1].ToString();
break;
}
i++;
}
Console.WriteLine("Result is " + results.ToString());
Thread.Sleep(999999);
}
}
答案 0 :(得分:3)
您可以使用Regex
这种模式:@"^.*?(?<numbers>\d{2}\w).*$"
。
示例:
var f = @"^.*?(?<numbers>\d{2}\w).*$";
var match = Regex.Match("NY 12A 1234B", f);
var result = match.Groups["numbers"].Value;
答案 1 :(得分:1)
没有正则表达式的另一个版本:
char a = source.First(pos => char.IsDigit(pos));
int b = source.IndexOf(a);
string result = source.Substring(b, 3);
Console.WriteLine(result);