像QQ那样将最近的几条消息合并到一起, 并不是什么难事, 我觉得核心就是时间间隔, 我这里做个假设, 比如小于5秒间隔的消息, 应该合并在一起显示.
代码如下:
import random
a = [(1, x) for x in xrange(2,100)]
part=[]
for i,x in enumerate(a):
if i==0:
(x)
else:
if not part:
(x)
else:
if abs(x-part[-1]) < 5:
(x)
else:
print part
part=[]
这个没啥好解释的, 就是小于5秒, 就加入到一个临时列表, 然后新出现的消息就和这个临时列表的最后一个比较, 如果间隔小于5, 就加入, 如果间隔大于5, 就print, 然后将临时列表设置为空.
第二版:
import random
a = [(1, x) for x in xrange(2,50)]
part=[]
print a
for x in a:
if not part:
(x)
else:
if abs(x-part[-1]) < 5:
(x)
else:
print part
part=[]
(x)
修正了第一版的问题, 大于5也应该作为下一轮临时列表中的函数, 并且我发现不需要用迭代函数enumerate了
第3版, 我发现每一个if中都使用了, 所以就把他们缩减了, 调整if就行:
import random
a = [(1, x) for x in xrange(2,50)]
part=[]
print a
for x in a:
if part:
if abs(x-part[-1]) > 5:
print part
part=[]
(x)
完