即使列表为空,C#列表计数也始终返回1
发布时间:2020-12-15 18:28:22 所属栏目:百科 来源:网络整理
导读:我正在尝试在C#中调试一个方法,但我的基本语法技能似乎缺乏!该方法接受日期列表作为逗号分隔的文本字符串.此字符串将转换为列表,然后进行处理.但是,即使将空字符串传递给方法,它仍然会在计算列表时输出1. 代码如下: public static int DaysLeft(DateTime e
我正在尝试在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()返回的每个“date”字符串,并且只增加计数器的有效日期. 像这样的东西: 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; (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |