Словари не упорядочены, и вы мало что можете сделать, чтобы изменить это, если не считать свой собственный подкласс dict
(не рекомендуется).Использование OrderedDict
будет работать, как показано в комментарии героев hiro, при условии, что вы помните, что порядок в OrderedDict
- это порядок вставки и не связан со значениями ключей.,(То же самое относится к порядку Python 3 dict
с.) Если a
и b
имеют одинаковые элементы, но в другом порядке, то результирующие OrderedDict
с не будут равны, если вы не сортируете a
и b
заранее.
Если вы хотите сравнить два dict
, где вы не можете легко определить порядок вставки, вам нужна структура данных, которая поддерживает неупорядоченные сравнения.У меня не было ваших данных, поэтому я должен был сделать некоторые.Я начал с этого ввода
>>> a
[[1, 3, 5, 7, 9], [4, 9, 14, 19, 24, 29, 34, 39], [8, 17, 26, 35, 44, 53, 62, 71], [9, 19, 29, 39, 49, 59, 69, 79, 89]]
>>> b
[[1, 3, 5, 7, 9], [4, 9, 14, 19, 24, 29, 34, 39], [8, 17, 26, 35, 44, 53, 62, 71]]
Как видите, a
имеет один дополнительный элемент, начинающийся 9
.
Измените код построения словаря, чтобы значения кортежей не были списками,потому что значения dict должны быть хешируемыми, чтобы следующий шаг работал:
>>> d = { k[0]: tuple(k[1:]) for k in a }
>>> d2= { k[0]: tuple(k[1:]) for k in b }
Затем вы можете преобразовать словари в наборы для неупорядоченного сравнения:
>>> s = set(d.items())
>>> s2 = set(d2.items())
>>> s == s2
False
И вы можетеиспользуйте операторы множеств, чтобы узнать, в чем разница:
>>> s2 <= s
True
>>> s - s2
set([(9, (19, 29, 39, 49, 59, 69, 79, 89))])