像QQ那样将最近的几条消息合并到一起

时间:2025-04-07 07:09:20

像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)