
我不确定是否有问题。
如果删除
.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)欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)