Reorder dictionary in python according to a list of values

后端 未结 6 1151
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-12 04:27

Let us consider a dictionary:

sample_dict={1:\'r099\',2:\'g444\',3:\'t555\',4:\'f444\',5:\'h666\'}

I want to re-order this dictionary in an

相关标签:
6条回答
  • 2021-01-12 04:40

    Using an OrderedDict or Eli's solution will probably be a good way to go, but for reference here is a simple way to obtain the list of values you want:

    [sample_dict[k] for k in desired_order_list]
    

    If you aren't completely sure that every element from desired_order_list will be a key in sample_dict, use either [sample_dict.get(k) ...] or [... for k in desired_order_list if k in sample_dict]. The first method will put None in for missing keys, the second method will only include values from the keys are are in the dict.

    0 讨论(0)
  • 2021-01-12 04:46

    Python dictionaries are unordered.

    Use OrderedDict instead.

    0 讨论(0)
  • 2021-01-12 04:46

    Use SortedDict provided by django (from django.utils.datastructures import SortedDict). SortedDict stores it's order in keyOrder attribute (which is just a list, so you can reorder it any way you like, anytime).

    If you don't have django installed or have no use for django, just lift the implementation django.utils.datatstructures. It doesn't depend on any other parts of django.

    0 讨论(0)
  • 2021-01-12 04:54

    If you're using an OrderedDict, you can do

    for key in [5,2,4,3,1]:
        my_ordered_dict[key] = my_ordered_dict.pop(key)
    

    This reinserts everything in your ordered dict in the sequence you want, such that later you can do

    my_ordered_dict.values()
    

    And get the list you suggested in the question.

    If you wrap the reinsertion in a try: ...; except KeyError: pass, you can reorder an OrderedDict even if not all the keys in your list are present.

    0 讨论(0)
  • 2021-01-12 04:59

    Answer for Python 3.6+

    Guido has assured dictionaries would be ordered from Python 3.7 onwards, and they already were as an experimental feature in 3.6. The answer has already been expanded on in Fastest way to sort a python 3.7+ dictionary.

    In this case, building a new dict with simple dictionary comprehension based on the items contained in the desired_order_list will do the trick.

    sample_dict = {1: 'r099', 2: 'g444', 3: 't555', 4: 'f444', 5: 'h666'}
    print(sample_dict)
    >>> {1: 'r099', 2: 'g444', 3: 't555', 4: 'f444', 5: 'h666'}
    
    desired_order_list = [5, 2, 4, 3, 1]
    
    reordered_dict = {k: sample_dict[k] for k in desired_order_list}
    print(reordered_dict)
    >>> {5: 'h666', 2: 'g444', 4: 'f444', 3: 't555', 1: 'r099'}
    
    0 讨论(0)
  • 2021-01-12 04:59

    What is the meaning of reordering the dictionary for you? Dictionaries are unordered data structures by their nature - they are used for lookup rather than order.

    Do you want to iterate over the dictionary in some specific order? Then just use your desired_order_list:

    for key in desired_order_list: 
      # d is the dictionary
      # do stuff with d[key]
    

    As others have mentioned, Python has an OrderedDict (in 2.7 or 3.x), but I don't think it's what you need here. "Reordering" it is just too inefficient. It's much better to just carry your dictionary along with the list of keys in desired order, together.

    If you still insist on an OrderedDict, just create a new OrderedDict, inserting the value into it in the order of desired_order_list.

    0 讨论(0)
提交回复
热议问题