1.研究了很长时间的版本排序
因为版本号没有按照一定的规则来所以就很难对其进行排序一开始想到的是冒泡排序
//for (int i = 0; i < arrFi.Length - 1; i++)
//{
// for (int j = i + 1; j < arrFi.Length; j++)
// {
// string iname = arrFi[i].Name.Replace("V", "").Replace(".txt", "");
// string jname = arrFi[j].Name.Replace("V", "").Replace(".txt", "");
// string[] igroup = iname.Split('.');
// string[] jgroup = jname.Split('.');
// FileInfo zj = null;
// if (Convert.ToInt32(jgroup[0]) > Convert.ToInt32(igroup[0]))
// {
// zj = arrFi[j];
// arrFi[j] = arrFi[i];
// arrFi[i] = zj;
// }
// else if (Convert.ToInt32(jgroup[0]) == Convert.ToInt32(igroup[0]))
// {
// if (Convert.ToInt32(jgroup[1]) > Convert.ToInt32(igroup[1]))
// {
// zj = arrFi[j];
// arrFi[j] = arrFi[i];
// arrFi[i] = zj;
// }
// else if (Convert.ToInt32(jgroup[1]) == Convert.ToInt32(igroup[1]))
// {
// if (Convert.ToInt32(jgroup[2]) > Convert.ToInt32(igroup[2]))
// {
// zj = arrFi[j];
// arrFi[j] = arrFi[i];
// arrFi[i] = zj;
// }
// else if (Convert.ToInt32(jgroup[2]) == Convert.ToInt32(igroup[2]))
// {
// if (Convert.ToInt32(jgroup[3]) > Convert.ToInt32(igroup[3]))
// {
// zj = arrFi[j];
// arrFi[j] = arrFi[i];
// arrFi[i] = zj;
// }
// }
// }
// }
// }
//}
写了很长的代码用了多重嵌套才实现效果
最后经过搜索发现C#内置了一个Version 对象
专门存放版本数据并且可以比较
经过简化代码如下:
ref就是相当于 return arrFi;
private void SortAsFileName(ref FileInfo[] arrFi)
{
Array.Sort(arrFi, delegate (FileInfo x, FileInfo y)
{
Version v1 = new Version(y.Name.Replace("V", "").Replace(".txt", ""));
Version v2 = new Version(x.Name.Replace("V", "").Replace(".txt", ""));
return v1.CompareTo(v2);
});
}