即使列表为空,C#列表计数也始终返回1

Dan*_*Dan 6 c# list count

我正在尝试在C#中调试一个方法,但我的基本语法技能似乎缺乏!该方法接受日期列表作为逗号分隔的文本字符串.此字符串将转换为列表,然后进行处理.但是,即使将空字符串传递给方法,它仍然会在计算列表时输出1.

代码如下:

public static int DaysLeft(DateTime endDate, DateTime startDate, Boolean excludeWeekends, String excludeDates)
    {
        int counter = 0;

        List<string> excludeDatesList = new List<string>(excludeDates.Split(','));

        counter = excludeDatesList.Count;

        return counter;
    }
Run Code Online (Sandbox Code Playgroud)

如果我作为excludeDates参数传递一个空字符串,它返回1.如果我传递一个日期它返回1.如果我传递两个日期,它返回2等等所以它是有效的,除非没有传入任何内容,当我希望它返回0但它实际上返回1.

谁能指出我正确的方向?

谢谢

dle*_*lev 10

即使对于一个空字符串,Split也会在数组中返回该字符串,因此列表将使用...一个空字符串创建,产生一个.Count1. [ 编辑:您可以调用excludeDates.Split(',', StringSplitOption.RemoveEmptyEntries),使其不会.

为了使您的函数按预期运行,您应该尝试解析从中返回的每个"日期"字符串Split(),并且只增加计数器的有效日期.

像这样的东西:

    int counter = 0;
    var possibleDates = excludeDates.Split(',');

    foreach (var dateStr in possibleDates)
    {
        // Right now it just counts "good" dates, though could also do something
        //  with each date as well
        DateTime dt;
        if (DateTime.TryParse(dateStr, out dt))
            counter++;
    }

    return counter;
Run Code Online (Sandbox Code Playgroud)

如果您正在寻找最简单的方法,您应该只检查参数以查看它是否为空字符串,并在这种情况下返回0:

if (string.IsNullOrEmpty(excludeDates))
    return 0;
Run Code Online (Sandbox Code Playgroud)


Arm*_*rat 8

分裂角色正在返回一个空元素.

请尝试使用excludeDates.Split(',', StringSplitOptions.RemoveEmptyEntries).