• 盘点一个Python列表(元素多样)处理的实战题目(使用正则表达式也可以实现)


    大家好,我是Python进阶者。

    一、前言

    前几天在Python白银交流群【凡人不烦人】问了一个Python列表处理的问题,提问截图如下:

    下面是他的部分数据:

    lst = ['(问答题)(2) 假设镀锌钢管', 'http://admintk.sc.zzstep.com/UpLoadImage/2019-10-10/a84f340e-6c67-42b1-8eae-3dc142818492.png)15暗配的清单工程量为50m,其余条件不变,依据上述相关定额计算分析镀锌钢管', 'http://admintk.sc.zzstep.com/UpLoadImage/2019-10-10/a84f340e-6c67-42b1-8eae-3dc142818492.png)15暗配项目的综合单价,并填入“工程量清单综合单价分析表”中。']
    

    二、实现过程

    这里【dcpeng】给了一份代码,如下所示:

    lst = [元素列表]
    # print(len(lst))
    new_lst = [lst[0]]
    for item in lst[1:]:
        new_item = item.split(')')
        new_lst.extend([new_item[0], new_item[1]])
    print(len(new_lst))
    print(new_lst)
    

    可以得到预期的结果:

    后来【甯同学】也给了一个代码,如下图所示:

    代码很秀,叹为观止!

    后来他自己又遇到了一个新需求,如下图所示:

    看上去还是挺复杂的,用上面的代码已经不能满足了,后来他自己提供了一份代码,如下图所示:

    l1 = sum([*map((lambda x: x.split(')') if 'png)' in x else [x]), lists)], [])
    l1 = [x for x in l1 if x != '']
    l2 = []
    nums = []
    for j, item in enumerate(l1):
        if 'png' in item:
            if item[0] != '!':
                b = ' '.join(l1[j - 1:j + 1]).split('![](')
                nums.append(j)
            else:
                b = item.split('![](')
                b = [x for x in b if x != '']
            l2.extend(b)
        else:
            l2.append(item)
    lists = [l2[j] for j in range(len(l2)) if j+1 not in nums]
    
    

    相当于方法一和方法二的结合版本,总算搞定了。

    后来他发了源码之后,【瑜亮老师】给了一份代码,使用正则表达式很快搞定,代码如下:

    import re
    data = '你上面发的这个字符串'
    temp = re.findall(r'>(.*?)<|src="(.*?)"', data)
    result = [i.replace('\u3000', ' ') for j in temp for i in j if i != '']
    print(result)
    
    

    【瑜亮老师】的正则表达式使用还是6啊!

    不过他后面还陆陆续续发不同的源码出来,每次发一个需求,就要改一次代码,让人也难顶。

    三、总结

    大家好,我是Python进阶者。这篇文章主要盘点了一个Python正则表达式处理的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

    最后感谢粉丝【凡人不烦人】提问,感谢【dcpeng】、【甯同学】、【瑜亮老师】给出的思路和代码解析,感谢【此类生物】、【猫药师Kelly】、【斌】、【ᯤ⁶ᴳ】等人参与学习交流。

  • 相关阅读:
    好看的壁纸网站
    python简介
    python学习之基本语法(1)
    信息系统开发方法
    数据库连接池的使用小结
    软件版本后的字母含义
    信息系统与信息化
    软考
    实施过程中的项目管理
    mysql查SQL执行速度
  • 原文地址:https://www.cnblogs.com/dcpeng/p/16777993.html
Copyright © 2020-2023  润新知