Console.WriteLine()输出截断的消息或顺序错误/不完整

时间:2019-01-21 01:08:19

标签: c# output console.writeline

好吧,我不知道为什么会这样,但这看起来很奇怪,因为我没有找到类似的东西:

...

您可以看到检查了整个字符串,我们可以看到整个输出,但是在控制台中,它看起来已被截断。与:

...

您注意到了吗?看一下前4行。并检查检查器。缺少一些tuple.Item1yuple.Item2

您可以在LINQ select上看到一个问题。但是我不知道为什么会这样。

...

您可以在其中看到完整的代码:

    private const string ClassName = "ClassName",
                         InheritedClass = "InheritedClass";

    private static void Main(string[] args)
    {
        var files = Directory.GetFiles(StaticPath, "*.cs", SearchOption.AllDirectories);

        var classes = files.Select(file => GetClassesInFile(file)).SelectMany(c => c).ToList();

        string fullMsg = string.Join(Environment.NewLine, classes.Select(tuple => $"{tuple.Item1}{(tuple.Item2.HasContent(string.Empty, " ") ? " : " + string.Join(", ", tuple.Item2) + " " : " ")}(on {Path.GetFileName(tuple.Item3)})"));
        Console.WriteLine(fullMsg);

        var unsealedClasses = classes.Where(c => !classes.Any(subClass => subClass.Item2.Contains(c.Item1))).ToList();

        string msg = $"Unsealed classes count: {unsealedClasses.Count} ({string.Join(", ", unsealedClasses.Select(c => c.Item1))})";
        Console.WriteLine(msg);

        Console.Read();
    }

    private static IEnumerable<Tuple<string, string[], string>> GetClassesInFile(string file)
    {
        return Regex.Matches(File.ReadAllText(file), $"(public|internal|private) class (?<{ClassName}>(.+?))( : (?<{InheritedClass}>(.+?))|)\n")
            .Cast<Match>()
            .Select(m => new Tuple<string, string[], string>(GetGroupValue(m, ClassName), GetGroupValue(m, InheritedClass).CleanLineBreak().Split(','), file))
            .Where(t => !string.IsNullOrEmpty(t.Item1));
    }

    private static string GetGroupValue(Match m, string groupName)
    {
        return m.Groups[groupName].Value.ToString();
    }
  • GetGroupValue从Regex Group索引器输出一个字符串。
  • GetClassesInFile输出一个IEnumerable of Tuple,其中Item1是类名,Item2是它依赖的类/接口,第三个Item是此类的文件路径。

注意:如您所见,我还在tuple.Item1上过滤空字符串或空字符串。

我不知道这里发生了什么。但这太奇怪了,我是第一次看到它。

编辑:

我查看了用户评论提到的输出高度(参考:Is there a limit on the output of Console Window?),我的输出超过了9001:

...

1 个答案:

答案 0 :(得分:2)

GameMovieClipSpriteTex类名的末尾有回车符\r。尝试用Trim()方法调用GetGroupValue

private static string GetGroupValue(Match m, string groupName)
{
    return m.Groups[groupName].Value.ToString().Trim();
}