首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何自定义对Directory.GetFiles()的返回值排序

如何自定义对Directory.GetFiles()的返回值排序
EN

Stack Overflow用户
提问于 2016-01-18 16:25:52
回答 1查看 108关注 0票数 2

我正在加载字符串数组中目录中的文件列表。我在用System.IO.Directory.GetFiles()

代码语言:javascript
复制
String[] path = Directory.GetFiles(batchElements[j].DocIdPath, "*.csv", SearchOption.AllDirectories);

我假设返回值的默认排序顺序是按名称排序的。因此,我的文件按以下顺序加载。

  • 2713_CFPB结算成本Booklet_2713_1.csv
  • 2713_CFPB结算成本Booklet_2713_10.csv
  • 2713_CFPB结算成本Booklet_2713_11.csv
  • 2713_CFPB结算成本Booklet_2713_2.csv
  • 2713_CFPB结算成本Booklet_2713_3.csv
  • 2713_CFPB结算成本Booklet_2713_4.csv
  • 2713_CFPB结算成本Booklet_2713_5.csv
  • 2713_CFPB结算成本Booklet_2713_6.csv
  • 2713_CFPB结算成本Booklet_2713_7.csv
  • 2713_CFPB结算成本Booklet_2713_8.csv
  • 2713_CFPB结算成本Booklet_2713_9.csv

但是相反,我想按这个顺序收集值。

  • 2713_CFPB结算成本Booklet_2713_1.csv
  • 2713_CFPB结算成本Booklet_2713_2.csv
  • 2713_CFPB结算成本Booklet_2713_3.csv
  • 2713_CFPB结算成本Booklet_2713_4.csv
  • 2713_CFPB结算成本Booklet_2713_5.csv
  • 2713_CFPB结算成本Booklet_2713_6.csv
  • 2713_CFPB结算成本Booklet_2713_7.csv
  • 2713_CFPB结算成本Booklet_2713_8.csv
  • 2713_CFPB结算成本Booklet_2713_9.csv
  • 2713_CFPB结算成本Booklet_2713_10.csv
  • 2713_CFPB结算成本Booklet_2713_11.csv

感谢帮助。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-18 16:34:19

你可以:

  • 仅使用Path.GetFileNameWithoutExtension获取文件名
  • 基于_的拆分
  • 获取最后一件物品
  • 使用int.Parseint.TryParse解析它
  • OrderBy中与LINQ一起使用该值

代码:

代码语言:javascript
复制
var output = path.OrderBy(p => 
                        int.TryParse(Path.GetFileNameWithoutExtension(p).Split('_').Last(), out temp) ?
                        temp : int.MaxValue);

如果需要一个数组或List<T>作为输出,那么将ToArray()ToList()附加到查询中。

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34859475

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档