吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 897|回复: 4
收起左侧

[Python 原创] Python多级列表场景计算算法及实现分享

[复制链接]
moduwusuowei 发表于 2024-8-15 10:30
最近项目组有个50万行的数据需要处理,看着都头大,想了半天,代码实现1小时才完成,特别分享出来给小伙伴看看,有更好想法的欢迎提出优化,为了方便展示只截取了部分数据


a = [[
    305,
    "144926190",
    "ENTER_mdwsw_wsw_3",
    ""
],
    [
        306,
        "144927044",
        "LEAVE_mdwsw_wsw_3",
        ""
    ],
    [
        313,
        "144937095",
        "ENTER_mdwsw_wsw_2",
        ""
    ],
    [
        303,
        "144938371",
        "ENTER_mdwsw_wsw_1",
        ""
    ],
    [
        304,
        "144938454",
        "LEAVE_mdwsw_wsw_1",
        ""
    ],
    [
        314,
        "144938529",
        "LEAVE_mdwsw_wsw_2",
        ""
    ]]

数据说明:
1.列表a是一个不限长度列表;
2.子列表:
第一项是id;
第二项是时间戳;
第三项是方法与事件,方法是第一个_之前的部分,共两类:ENTER与LEAVE,事件是第一个_之后的部分;
第四项是对应事件的LEAVE与ENTER时间之差,目前为空的是待计算的;


计算规则:

1.从第一个子列表开始,找到事件相同,方法不同的计算时间差,更新到LEAVE事件的第四个元素;
2.中间如果还有事件,同样计算同名事件的时间差,并将其赋给LEAVE事件的第四个元素,同时这个时间还要用开头事件时间差再去除这部分;
3.同一个事件中间的列表不一定是固定的;
4.同一个事件如果ENTER与LEAVE之间还有其他事件的ENTER与LEAVE,在计算的时候也要去除时间差;
5.还需要考虑两个子列表的id相差是否为1,若为1,则是相邻的事件,若不是1,则存在嵌套事件;


计算场景:
1.相邻型
数据:a = [
[
    305,
    "144926190",
    "ENTER_mdwsw_wsw_3",
    ""
],
    [
        306,
        "144927044",
        "LEAVE_mdwsw_wsw_3",
        ""
    ]
]

只需填充id=306的第四个元素,计算方式:144927044-144926190=854
更新:
[
        306,
        "144927044",
        "LEAVE_mdwsw_wsw_3",
        854
]

2.嵌套型
数据 a= [[
        313,
        "144937095",
        "ENTER_mdwsw_wsw_2",
        ""
    ],
    [
        303,
        "144938371",
        "ENTER_mdwsw_wsw_1",
        ""
    ],
    [
        304,
        "144938454",
        "LEAVE_mdwsw_wsw_1",
        ""
    ],
    [
        314,
        "144938529",
        "LEAVE_mdwsw_wsw_2",
        ""
    ]]
此时需要计算的是两次LEAVE_事件的耗时,由于存在嵌套,需要分三步计算:
第一步:先计算313、314,这一组:144938529-144937095 = 1434,此时数据还不能直接更新在314上,因为,中间涉及嵌套耗时;
第二步:再计算303、304,这一组:144938454-144938371 = 83, 此时可以将83更新到数据304上,即:
        [
        304,
        "144938454",
        "LEAVE_mdwsw_wsw_1",
        83
    ]
第三步:计算最终314数据:1434-83 = 1351,  更新数据到314:
        [
        314,
        "144938529",
        "LEAVE_mdwsw_wsw_2",
        1351
    ]
这样就算完成计算过程,中间如果涉及多层嵌套依旧如此计算;

思路:
(())()()(()())  算法题:括号有效性的延伸

代码:

[Python] 纯文本查看 复制代码
a = [
    [305, "144926194", "ENTER_Can_Interrupt_CANFD00_Cat2", ""],
    [306, "144927048", "LEAVE_Can_Interrupt_CANFD00_Cat2", ""],
    [313, "144937099", "ENTER_Spi_Interrupt_SCB5_Cat2", ""],
    [303, "144938375", "ENTER_SpiSeqEndNotification_SBC", ""],
    [304, "144938458", "LEAVE_SpiSeqEndNotification_SBC", ""],
    [314, "144938533", "LEAVE_Spi_Interrupt_SCB5_Cat2", ""]
]


# 定义类:实现堆栈的,pop,push,is_empty,is_full功能
class Stack:
    def __init__(self):
        self.stack = []
        self.time_list = []

    def push(self, item):
        if self.is_empty():
            # print("push item:", item)
            self.stack.append(item)
        else:
            # print("888"*8)
            # 获取栈尾
            last = self.stack[-1]
            method_last, event_last = last[2].split("_", 1)
            method_item, event_item = item[2].split("_", 1)
            # print("1111", method_last, event_last)
            # 如果栈尾元素与待出栈元素相同,则出栈
            if event_last == event_item:
                # 计算一个时间变量
                time_diff = int(item[1]) - int(last[1])
                if self.time_list:
                    time_diff -= self.time_list[-1]
                item[3] = time_diff
                # print("3333", time_diff)
                print("2222", item)
                # 这个时间变量存储到time_list
                self.stack.pop()
                if not self.is_empty():
                    self.time_list.append(time_diff)


            # 如果栈尾元素与待出栈元素不同,则入栈
            else:
                # print("push item:", item)
                self.stack.append(item)
        # print("xxxxxx",self.time_list)


    def pop(self, item):
        if not self.is_empty():
                return self.stack.pop()

    def is_empty(self):
        return len(self.stack) == 0

    def is_full(self):
        return len(self.stack) == 10


if __name__ == '__main__':
    s = Stack()

    for i in a:
        s.push(i)

免费评分

参与人数 1吾爱币 +7 热心值 +1 收起 理由
苏紫方璇 + 7 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

zlqhysy 发表于 2024-8-15 13:44
看来我得学学python了
music984 发表于 2024-8-15 15:25
HR741158 发表于 2024-8-16 11:02
15090878185 发表于 2024-8-30 11:22
收藏,学习了
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-12-13 03:52

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表