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

来源:互联网 发布:数据结构与算法ppt 编辑:程序博客网 时间:2024/05/14 19:55

像QQ那样将最近的几条消息合并到一起, 并不是什么难事, 我觉得核心就是时间间隔, 我这里做个假设, 比如小于5秒间隔的消息, 应该合并在一起显示.


代码如下:

import randoma = [random.randint(1, x) for x in xrange(2,100)]part=[]for i,x in enumerate(a):    if i==0:        part.append(x)    else:        if not part:            part.append(x)        else:            if abs(x-part[-1]) < 5:                part.append(x)            else:                print part                part=[]

这个没啥好解释的, 就是小于5秒, 就加入到一个临时列表, 然后新出现的消息就和这个临时列表的最后一个比较, 如果间隔小于5, 就加入, 如果间隔大于5, 就print, 然后将临时列表设置为空.


第二版:

import randoma = [random.randint(1, x) for x in xrange(2,50)]part=[]print afor x in a:    if not part:        part.append(x)    else:        if abs(x-part[-1]) < 5:            part.append(x)        else:            print part            part=[]            part.append(x)

修正了第一版的问题, 大于5也应该作为下一轮临时列表中的函数, 并且我发现不需要用迭代函数enumerate了


第3版, 我发现每一个if中都使用了part.append, 所以就把他们缩减了, 调整if就行:

import randoma = [random.randint(1, x) for x in xrange(2,50)]part=[]print afor x in a:    if part:        if abs(x-part[-1]) > 5:            print part            part=[]    part.append(x)


0 0
原创粉丝点击