你好我得到了一个字符串数组,它们是我自己制作的格式为H:M:S:MS
示例字符串:
0:0:4:410
0:0:1:425
0:0:1:802
0:0:1:509
0:0:1:674
0:0:1:628
0:0:2:76
如何在arraylist中 sum / avg / min / max 这些项的值?
Arraylist名称为arrayLL
。
我是c#的新手,所以希望有人能告诉我如何使用字符串。
添加到数组的函数是:
if (Session["DT"].ToString() != "")
{
TimeSpan ts = ((DateTime)Session["DT2"]).Subtract((DateTime)Session["DT"]);
Session["TimeL"] = ts.Hours.ToString() + ":"
+ ts.Minutes.ToString() + ":"
+ ts.Seconds.ToString() + ":"
+ ts.Milliseconds.ToString();
}
答案 0 :(得分:2)
假设数字代表小时,分钟,秒和毫秒,您可以尝试以下操作:
// Empty list you will populate:
List<int> durationsInMilliseconds = new List<int>();
// Loop through your existing data, and calculate all
// durations into milliseconds:
foreach (string word in yourDurationArray)
{
string[] values = s.Split(':');
int hoursAsMilliseconds = Integer.parse(values[0]) * 60 * 60 * 1000;
int minutesAsMilliseconds = Integer.parse(values[1]) * 60 * 1000;
int secondsAsMilliseconds = Integer.parse(values[2]) * 1000;
int sumDurationAsMilliseconds = hoursAsMilliseconds +
minutesAsMilliseconds +
secondsAsMilliseconds +
Integer.parse(values[3]);
durationsInMilliseconds.add(sumDurationAsMilliseconds);
}
现在您应该有一个Integer类型列表(durationsInMilliseconds
),其中包含单个可比较格式的数字。有了这个,你应该能够做任何你需要的计算。
(PS:如果您需要与原始输入数据格式相同的结果,则必须添加一个操作,以便从MS计算回小时,分钟和秒......)
答案 1 :(得分:1)
因为我猜他们是持续时间,所以我应该这样做
var enu_ts = yourvariable.OfType<string>().Select(x =>
TimeSpan.Parse(x, @"h\:m\:s\:fff", CultureInfo.InvariantCulture));
最高
var max = enu_ts.Max().ToString();
最小
var max = enu_ts.Min().ToString();
答案 2 :(得分:1)
foreach(string s in dateString)
{
spanList[i] = TimeSpan.Parse(s);
total=total.Add(spanList[i++]);
}
Response.Write("Max TimeSpan:"+spanList.Max<TimeSpan>());
Response.Write("Min TimeSpan:" + spanList.Min<TimeSpan>());
Response.Write("Total Sum of TimeSpan:"+total);