用于排序元组的 Python 字典,可以做得更好吗?

标签 python sorting generator iterable dictionary

我有一个具有以下特征的输入字典:

  • 每个值都可以是整数、字符串或可迭代对象(字符串除外)。
  • 如果元素是可迭代的,则该可迭代中的每个元素都将只是一个字符串或整数。

例如:

mydict = {
    'one': 1,
    'two': '23',
    'three': 3,
    'four': [
        7,
        '6',
        5,
        8
    ],
    'nine': 9
}

我需要将输入转换为元组列表,其中每个元组都是一个键/值对。对于可迭代元素,每个元素都有一个键/值对,按值排序。例如,上面的输出应该是:

('four', 5)
('four', 7)
('four', 8)
('four', '6')
('nine', 9)
('one', 1)
('three', 3)
('two', '2')

我目前使用以下生成器实现了这一点:

def dict_to_sorted_tuples(unsorted_dict):
    for key in sorted(unsorted_dict):
        if isinstance(unsorted_dict[key], basestring):
            yield key, unsorted_dict[key]
            continue
        try:
            for v in sorted(unsorted_dict[key]):
                yield key, v
        except:
            yield key, unsorted_dict[key]

print list(dict_to_sorted_tuples(mydict))

我觉得这可以用更简洁的方式完成,有什么改进建议吗?

最佳答案

>>> sorted((i,k) for i,j in mydict.items() for k in ([j] if isinstance(j, str) or isinstance(j, int) else j))
[('four', 5), ('four', 7), ('four', 8), ('four', '6'), ('nine', 9), ('one', 1), ('three', 3), ('two', '2')]

这里的想法是,如果值是 intstr,则将其放入 list 中。现在问题得到了简化,因为您有一个可以随时迭代的值

如果你真的确定你只需要检查 intstr(不是子类或 unicode),你可以使用

sorted((i,k) for i,j in mydict.items() for k in ([j] if type(j) in (int, str) else j))

如果值可以是 unicode,则应使用 isinstance(j, basestring) 而不是 isinstance(j, str)

关于用于排序元组的 Python 字典,可以做得更好吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6435083/

相关文章:

python - Matplotlib 饼图楔形透明度?

java - 排序——是否可以很好地使用子数组进行排序?

java - java8流图在这里做什么?

JavaScript 生成器 - 如何在使用 .next() 调用时跳过 yield?

javascript - 将产量响应分配给变量

python - %d 和 %s 的目的是什么

python - 我如何更好地处理涉及Unicode字符以及从ASCII来回往返的编码和解码

python - python 中更快的方法

java - 为什么 Java 在此算法中产生长度 > 10000 的错误输出?

node.js - node.js 是否支持产量?