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

标签 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;
    }

如果我传递一个空字符串作为 excludeDates 参数,它返回 1。如果我传递一个日期,它返回 1。如果我传递两个日期,它返回 2 等等。所以它有点工作,除非没有传递任何东西在,当我期望它返回 0 但它实际上返回 1 时。

谁能指出我正确的方向?

谢谢

最佳答案

即使对于一个空字符串,Split 也会返回数组中的 那个字符串,因此列表将创建为...一个空字符串,生成一个 .Count 为 1。[编辑:您可以调用 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;

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

if (string.IsNullOrEmpty(excludeDates))
    return 0;

关于C# 列表计数始终返回 1,即使列表为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6763024/

相关文章:

c# - 之前的 "new"运算符会怎样?

php - 如何计算每页使用的 MySQL 查询总数?

python - 计算一个 DataFrame 中的条件值并将结果添加到另一个 DataFrame

mysql - 使用 MySQL 中的附加列过滤器从 Information Schema 获取行数

Python:类属性的继承(列表)

c# - DLLImport 找不到 dll

c# - 如何将用户从 MVC 应用程序保存到 Web API 并对其进行身份验证

c# - 在 C# 中找不到路径的一部分

python - 按顺序将两个不同列表中的值分配给Python中数据帧中的列

java - arraylist isEmpty() 疑惑与疑问