我看到你在使用ZMQ,所以我想你需要更好的性能。如果是这样,请尝试使用cPickle模块(在标准Python库中提供)打包此列表,而不是将其转换为字符串。你知道吗
下面是比较两种方法效率的代码:import time
import cPickle
import random
random.seed()
l = [ random.random()*1000 for i in xrange(100000) ]
t0 = time.time()
s1 = ','.join(map(str,l))
t1 = time.time() - t0
t0 = time.time()
s2 = cPickle.dumps(l, -1)
t2 = time.time() - t0
print 's1: len1=%s t1=%s' % (len(s1), t1)
print 's2: len2=%s t2=%s' % (len(s2), t2)
print 's2/s1: len2/len1=%s t2/t1=%s' % (float(len(s2))/len(s1), t2/t1)
它的输出:s1: len1=1389129 t1=0.281008005142
s2: len2=900206 t2=0.0193469524384
s2/s1: len2/len1=0.648036287487 t2/t1=0.0688484031925
您可以看到,cPickle方式要快得多(快了14.5倍),而且就必须传输的数据大小而言,效率也很高(64%)。你知道吗
对于从pickled对象获取列表,应该使用l = cPickle.loads(s2)
希望有帮助。你知道吗