Question

I've been searching around for a little while to figure out how to confirm a string begins with a number. I came across a regex statement '/^\d/' which I can confirm says if starts with digit. However I can not seem to get it to work in the code below. Where did I went wrong in the statement if(Regex.Match(info,"/^\d/"))?

//String attachbody is the attachment body from an email C read into a string
string[] data = Regex.Split(attachbody, "\n");

foreach (String info in data)
{
    if (Regex.Match(info,"/^\d/"))
    {
        string[] tabbedHeaderData = Regex.Split(info, "\t");
        TicketID = tabbedHeaderData[0].ToString();
        Status = tabbedHeaderData[1].ToString();
        URL = tabbedHeaderData[2].ToString();
        InitCats = tabbedHeaderData[3].ToString();
        PostRevCats = tabbedHeaderData[4].ToString();
        ListNumClosed = tabbedHeaderData[5].ToString();

        Console.WriteLine(TicketID);
        Console.WriteLine(Status);
        Console.WriteLine(URL);
        Console.WriteLine(InitCats);
        Console.WriteLine(PostRevCats);
        Console.WriteLine(ListNumClosed);
        Console.ReadLine();
    }
}

example data (tab delimited):
TicketID Status URL InitCats PostRevCats ListNumClosed 555555 Closed http://5555555.com/searcho Malicious Sites 55555

Was it helpful?

Solution

Your regex is wrong. /.../ is javascript convention for defining regular expressions. Try like this in C#:

if (Regex.IsMatch(info, @"^\d"))

Also notice that you should use the IsMatch method which returns boolean or your code won't even compile.

And if you wanted to match that the string starts with one or more digits:

if (Regex.IsMatch(info, @"^\d+"))

OTHER TIPS

You don't need a regex for this. Try

if (info.Length > 0 && char.IsDigit(info[0]))
{
   ...
}

If you want to use the regex, take out the // so it's just Regex.IsMatch(info,@"^\d").

It's the format of the string that you've supplied to Regex.Match.

The correct format would be:

Regex.Match(info,@"^\d")

The @ means that escape characters (like the backward slash) are treated as normal characters. Without it your regex would need to be "^\\d".

Your regex is wrong. .Net doesn't use perl-style regexs. The correct expression is @"^\d".

And you should use Regex.IsMatch(...) if you're not going to use the MatchCollection from .Match for anything:

RegEx.IsMatch(info, @"^\d")

If your only trying to find out if the string begins with a number. Like above, you canskip using regex. Just use Substring, remove the first character and test if it is a number.

Now if your trying to remove the entire number, then I would convert the string to a char array, and test the chars.

pseudo string s = "" for each c in chars{ if c is number then s += c else exit for } convert the s to an integer, you got the number at the begining of the string.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top