python:如何获取dict的子集

Bin*_*hen 7 python

我有一个有许多元素的字典,我想编写一个函数,可以返回给定索引范围内的元素(将dict视为数组):

get_range(dict, begin, end):
    return {a new dict for all the indexes between begin and end}
Run Code Online (Sandbox Code Playgroud)

怎么做?

编辑:我不是要求使用密钥过滤器...例如)

{"a":"b", "c":"d", "e":"f"}

get_range(dict, 0, 1) returns {"a":"b", "c":"d"} (the first 2 elements)
Run Code Online (Sandbox Code Playgroud)

我不关心排序......其实我正在实现服务器端分页...

ken*_*ytm 16

编辑:未订购字典.get_range每当修改字典时,都不可能返回相同的切片.如果您需要确定性结果,请将其替换dict collections.OrderedDict.

无论如何,你可以使用itertools.islice:

import itertools
def get_range(dictionary, begin, end):
  return dict(itertools.islice(dictionary.iteritems(), begin, end+1)) 
Run Code Online (Sandbox Code Playgroud)

以前按键过滤的答案保留如下:

使用@ Douglas算法,我们可以使用生成器表达式来简化它:

def get_range(dictionary, begin, end):
  return dict((k, v) for k, v in dictionary.iteritems() if begin <= k <= end)
Run Code Online (Sandbox Code Playgroud)

顺便说dict一下,不要用作变量名,因为你可以看到这里dict是字典的构造函数.

如果您使用的是Python 3.x,则可以直接使用字典理解.

def get_range(dictionary, begin, end):
  return {k: v for k, v in dictionary.items() if begin <= k <= end}
Run Code Online (Sandbox Code Playgroud)