从redis封装Unicode

从redis封装Unicode,第1张

从redis封装Unicode

我不确定是否有问题。

如果删除

.enpre('utf8')
代码中的所有调用,它将生成一个正确的文件,即该文件与您当前代码生成的文件相同。

>>> r_server = redis.Redis('localhost')>>> r_server.keys()[]>>> r_server.sadd(u'Hauptstädte', u'東京', u'Godthåb',u'Москва')3>>> r_server.keys()['Hauptstxc3xa4dte']>>> r_server.smembers(u'Hauptstädte')set(['Godthxc3xa5b', 'xd0x9cxd0xbexd1x81xd0xbaxd0xb2xd0xb0', 'xe6x9dxb1xe4xbaxac'])

这表明键和值是UTF8编码的,因此

.enpre('utf8')
不是必需的。该
redis
模块的默认编码为UTF8。创建客户端时可以通过传递编码来更改此设置,例如
redis.Redis('localhost',encoding='iso-8859-1')
,但没有理由。

如果启用带有的响应解码

depre_responses=True
则将使用客户端连接的编码将响应转换为unipre。这只是意味着您不需要显式解码返回的数据,
redis
而是将为您完成此 *** 作并返回一个unipre字符串:

>>> r_server = redis.Redis('localhost', depre_responses=True)>>> r_server.keys()[u'Hauptstxe4dte']>>> r_server.smembers(u'Hauptstädte')set([u'Godthxe5b', u'u041cu043eu0441u043au0432u0430', u'u6771u4eac'])

因此,在第二个示例中,将从Redis检索到的数据写入文件中,如果启用响应解码,则需要使用所需的编码打开输出文件。如果这是默认编码,则可以使用

open()
。否则,您可以
precs.open()
在写入文件之前使用或手动编码数据。

import precscities_tag = u'Hauptstädte'with precs.open('capitals.txt', 'w', encoding='utf8') as f:    while r_server.scard(cities_tag) != 0:        city = r_server.srandmember(cities_tag)        f.write(city + 'n')        r_server.srem(cities_tag, city)


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/4915597.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-12
下一篇2022-11-12

发表评论

登录后才能评论

评论列表(0条)

    保存