我正在构建一些非常大的查找表在Redis。我有一些简单的代码,当循环遍历dict以在Redis散列(通过管道)中为使用hset()的每个项设置一个值时,这些代码可以正常工作。
foo = {"1234": "5678", "abcd": "efgh", ... }
with self.db.pipeline() as pipe:
for foo in bar:
pipe.hset("lookup_table", foo["key"], foo["value"])
pipe.execute()这对一个大的混蛋来说是很慢的。为了加快速度,我希望能够将多个项设置为到管道的映射,而不必在管道上循环。现在不再推荐hmset()了,hset()似乎可以通过关键字arg接受映射。我试图做以下工作:
with self.db.pipeline() as pipe:
pipe.hset("lookup_table", mapping=foo)
pipe.execute()但这会产生错误TypeError: hset() got an unexpected keyword argument 'mapping'。我是不是不正确地使用hset()?还是我错误地认为hset()可以以这种方式接受多个项目?
我在Python3.7.5中使用py-redis 3.4.1。
发布于 2020-04-10 11:20:28
这似乎是一个已知的问题,如这里所示-> https://github.com/andymccurdy/redis-py/issues/1310#issuecomment-603081122。
正如您在链接的图像中看到的那样,PyPi中的源代码具有不包含关键字mapping的函数签名的hset。您应该在安装py-redis时验证是否存在相同的问题,并遵循该票证。要解决这个问题,您可以直接从master分支克隆,以便使用该特性。
发布于 2021-02-16 20:17:40
用
pip install -U redis帮我解决了这个问题。
https://stackoverflow.com/questions/61138821
复制相似问题