zoukankan      html  css  js  c++  java
  • PYTHON字典排序

    新学习了一些关于字典的操作:


    keylst = list(myDict.keys()) #在list中列出所有的keys
    vallst = list(myDict.values()) #在list中列出所有的vals
    itelst = list(myDict.items()) #在list中列出所有的key与val,以tuple形式


    利用items与zip对字典进行排序

    items能把字典key与val拆成一对tuple(只限1个val的key)

    zip函数接受任意多个序列作为参数,返回一个tuple列表 (引用自:http://www.cnblogs.com/ymjyqsx/p/6113495.html(对zip的用法写的很详细

    DictSortByKey = dict(sorted(myDict.items())) #以key进行排序,生成新的字典。因为items()拆出元素的顺序是默认以key为先


    DictSortByKey2 = dict(sorted(zip(myDict.keys(), myDict.values()))) #同上

    DictSortByVal = dict(sorted(zip(myDict.values(), myDict.keys()))) #以val进行排序,生成新的字典,但是val与key互换位置

    #慎用,因为当Val有重复值时会导致部分key被吞掉
    DictSortByVal2 = dict(zip(DictSortByVal.values(), DictSortByVal.keys())) #将上面的字典翻转,生成原字典以val进行排序的新字典


    利用sorted(iterable, key)来进行排序,一步到位

    #推荐使用,单纯排序。

    OneStepKey = dict(sorted(myDict.items(), key=lambda x:x[0])) #以key进行排序,生成新的字典
    OneStepVal = dict(sorted(myDict.items(), key=lambda x:x[1])) #以val进行排序,生成新的字典

  • 相关阅读:
    HDU5000 (DP + 规律)
    HDU5127 神坑题---vector 、 list 、 deque 的用法区别
    HDU5128 细心、细心、细心
    dij单源最短路纯模板
    POJ 1236 SCC+缩点
    SCC(强连通分量)
    用树状数组求数组内的逆序对数
    HDU 1811 并查集
    大数模板,只要不是手敲,非常好用
    市赛
  • 原文地址:https://www.cnblogs.com/phinza/p/9927684.html
Copyright © 2011-2022 走看看