我正在尝试调试 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/