我有一个程序,必须使用regexp输出确切长度的子字符串。
但是它还会输出更长的子串,这些子串与格式匹配。
输入:asb,asd asdf,asdfg
预期输出(长度= 3):asb asd
实际输出:asb asd asd asd

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;

namespace LR3_2
    {
    class Program
    {
        static void regPrint(String input, int count)
        {
            String regFormat = @"[a-zA-Z]{" + count.ToString() + "}";
            Regex reg = new Regex(regFormat);
            foreach (var regexMatch in reg.Matches(input))
            {
                Console.Write(regexMatch + " ");
            }

            //Match matchObj = reg.Match(input);
            //while (matchObj.Success)
            //{
            //    Console.Write(matchObj.Value + " ");
            //    matchObj = reg.Match(input, matchObj.Index + 1);
            //}
        }

        static void Main(string[] args)
        {
            String input = " ";
            //Console.WriteLine("Enter string:");
            //input = Console.ReadLine();
            //Console.WriteLine("Enter count:");
            //int count = Console.Read();

            input += "a as asb, asd asdf  asdfg";
            int count = 3;
            regPrint(input, count);
        }
    }
}

最佳答案

在表达式中添加\b,表示“单词的开头或结尾”,例如:

\b[a-zA-Z]{3}\b


在您的代码中,您应该执行以下操作:

String regFormat = @"\b[a-zA-Z]{" + count.ToString() + @"}\b";


要在编写自己的测试程序之前测试正则表达式,可以使用ExpressoThe Regulator之类的工具。他们实际上可以帮助您编写表达式并进行测试。

关于c# - C#正则表达式的确切长度,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/10847286/

10-17 00:40