当前位置: 首页 > news >正文

C# 字典Dictionary<TKey,TValue>排序整理

准备

1、Student 类

public class Student
{
    public string name {get; set;}
    public int age {get; set;}
    public int score {get; set;}
}

2、dumpDictionary 方法

void dumpDictionary(Dictionary<int, Student> stuDict, string desc)
{
    Console.WriteLine(desc);
    foreach (KeyValuePair<int, Student> kvp in stuDict)
    {
        Console.WriteLine("{0} : {1} {2} {3}", kvp.Key, kvp.Value.name, kvp.Value.age, kvp.Value.score);
    }
}

3、原始字典

Dictionary<int, Student> stuDict = new Dictionary<int, Student> {
    [4] = new Student() {name = "张三", age = 20, score = 95},
    [5] = new Student() {name = "李四", age = 19, score = 99},
    [1] = new Student() {name = "王五", age = 21, score = 95},
    [3] = new Student() {name = "赵六", age = 20, score = 90},
    [6] = new Student() {name = "陈七", age = 22, score = 95},
    [2] = new Student() {name = "刘八", age = 21, score = 92}
};
dumpDictionary(stuDict, "-----原始字典-----");
// -----原始字典-----
// 4 : 张三 20 95
// 5 : 李四 19 99
// 1 : 王五 21 95
// 3 : 赵六 20 90
// 6 : 陈七 22 95
// 2 : 刘八 21 92

按键(Key)排序

OrderBy/OrderByDescending

// 升序
stuDict = stuDict.OrderBy(kv => kv.Key).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Key 升序-----");
// -----按 Key 升序-----
// 1 : 王五 21 95
// 2 : 刘八 21 92
// 3 : 赵六 20 90
// 4 : 张三 20 95
// 5 : 李四 19 99
// 6 : 陈七 22 95

// 降序
stuDict = stuDict.OrderByDescending(kv => kv.Key).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Key 降序-----");
// -----按 Key 降序-----
// 6 : 陈七 22 95
// 5 : 李四 19 99
// 4 : 张三 20 95
// 3 : 赵六 20 90
// 2 : 刘八 21 92
// 1 : 王五 21 95

SortedDictionary

SortedDictionary<int, Student> sortStuDict = new SortedDictionary<int, Student> (stuDict);
Console.WriteLine("-----SortedDictionary-----");
foreach (KeyValuePair<int, Student> kvp in sortStuDict)
{
    Console.WriteLine("{0} : {1} {2} {3}", kvp.Key, kvp.Value.name, kvp.Value.age, kvp.Value.score);
}
// -----SortedDictionary-----
// 1 : 王五 21 95
// 2 : 刘八 21 92
// 3 : 赵六 20 90
// 4 : 张三 20 95
// 5 : 李四 19 99
// 6 : 陈七 22 95

ps

SortedDictionary 默认升序。

按值(Value)排序

OrderBy/OrderByDescending

单属性排序

// 升序
stuDict = stuDict.OrderBy(kv => kv.Value.age).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 age 属性升序-----");
// -----按 Value 的 age 属性升序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 3 : 赵六 20 90
// 1 : 王五 21 95
// 2 : 刘八 21 92
// 6 : 陈七 22 95

// 降序
stuDict = stuDict.OrderByDescending(kv => kv.Value.score).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 score 属性降序-----");
// -----按 Value 的 score 属性降序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 1 : 王五 21 95
// 6 : 陈七 22 95
// 2 : 刘八 21 92
// 3 : 赵六 20 90

嵌套排序

// 按 Value 的 score 属性降序,score 相同则按 Value 的 age 升序
stuDict = stuDict.OrderByDescending(kv => kv.Value.score).ThenBy(kv => kv.Value.age).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 score 属性降序,score 相同则按 Value 的 age 升序-----");
// -----按 Value 的 score 属性降序,score 相同则按 Value 的 age 升序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 1 : 王五 21 95
// 6 : 陈七 22 95
// 2 : 刘八 21 92
// 3 : 赵六 20 90

// 按 Value 的 age 属性升序,age 相同则按 Key 降序
stuDict = stuDict.OrderBy(kv => kv.Value.age).ThenByDescending(kv => kv.Key).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 age 属性升序,age 相同则按 Key 降序-----");
// -----按 Value 的 age 属性升序,age 相同则按 Key 降序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 3 : 赵六 20 90
// 2 : 刘八 21 92
// 1 : 王五 21 95
// 6 : 陈七 22 95

LINQ语句

// 升序
stuDict = (from pair in stuDict orderby pair.Value.age select pair).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 age 属性升序-----");
// -----按 Value 的 age 属性升序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 3 : 赵六 20 90
// 1 : 王五 21 95
// 2 : 刘八 21 92
// 6 : 陈七 22 95

// 降序
stuDict = (from pair in stuDict orderby pair.Value.score descending select pair).ToDictionary(kv => kv.Key, kv => kv.Value);
dumpDictionary(stuDict, "-----按 Value 的 score 属性降序-----");
// -----按 Value 的 score 属性降序-----
// 5 : 李四 19 99
// 4 : 张三 20 95
// 1 : 王五 21 95
// 6 : 陈七 22 95
// 2 : 刘八 21 92
// 3 : 赵六 20 90

参考:

Enumerable.ToDictionary 方法

SortedDictionary<TKey,TValue> 类

关于C#:根据键对字典进行排序

C#中Dictionary<TKey,TValue>排序方式

相关文章:

  • 协同软件市场一盘散沙 春种能否秋收心中没底
  • bat 与或非
  • 独立软件开发商,出路何在?
  • Lua实战之不使用循环逆序输出一个数组
  • VS Code快速生成C#注释头
  • 10个装机最贵与免费的十大软件下载
  • VS 和 VS Code 更换字体
  • .NET值类型变量“活”在哪?
  • Lua do-end
  • VS Code 安装 VSIX 插件
  • 平台为王:Microsoft Office System为什么成功?
  • VS Code 对 Lua 代码格式化
  • 2020-拥抱经历,磨砺己身
  • 个人理财规划五步曲
  • AS报错:Didn‘t find class “okhttp3.OkHttpClient$Builder“ on path: DexPathList[[...]]
  • 2017前端实习生面试总结
  • angular2开源库收集
  • C++11: atomic 头文件
  • C++入门教程(10):for 语句
  • Gradle 5.0 正式版发布
  • Java应用性能调优
  • JS 面试题总结
  • Material Design
  • nginx 配置多 域名 + 多 https
  • node.js
  • spark本地环境的搭建到运行第一个spark程序
  • Sublime Text 2/3 绑定Eclipse快捷键
  • vue:响应原理
  • 闭包--闭包作用之保存(一)
  • 初识 webpack
  • 经典排序算法及其 Java 实现
  • 前嗅ForeSpider教程:创建模板
  • 如何利用MongoDB打造TOP榜小程序
  • 译米田引理
  • 机器人开始自主学习,是人类福祉,还是定时炸弹? ...
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • ​2020 年大前端技术趋势解读
  • ​软考-高级-系统架构设计师教程(清华第2版)【第15章 面向服务架构设计理论与实践(P527~554)-思维导图】​
  • #### go map 底层结构 ####
  • (2009.11版)《网络管理员考试 考前冲刺预测卷及考点解析》复习重点
  • (33)STM32——485实验笔记
  • (C)一些题4
  • (Forward) Music Player: From UI Proposal to Code
  • (k8s中)docker netty OOM问题记录
  • (附源码)spring boot校园拼车微信小程序 毕业设计 091617
  • (附源码)springboot优课在线教学系统 毕业设计 081251
  • (十一)手动添加用户和文件的特殊权限
  • (算法设计与分析)第一章算法概述-习题
  • (万字长文)Spring的核心知识尽揽其中
  • (一)使用IDEA创建Maven项目和Maven使用入门(配图详解)
  • (转)大型网站架构演变和知识体系
  • ***通过什么方式***网吧
  • **PHP分步表单提交思路(分页表单提交)
  • .halo勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法