多维数组降一维——自码土法递归降维人都难理清的复杂多维数组。

发布于:2022-12-02 ⋅ 阅读:(290) ⋅ 点赞:(0)

【点击此处跳转笔记正文】

Python 官网https://www.python.org/




  自学并不是什么神秘的东西,一个人一辈子自学的时间总是比在学校学习的时间长,没有老师的时候总是比有老师的时候多。
            —— 华罗庚


等风来,不如追风去……


复杂得读不清的:
多维数组降维
(自研看似“无懈可击”的土法)


目 录


回页首

  我要想再次升级我的mypycolor工具,需要用到对多维数组降维(降成一维)。以前看过相关文章,还是写得很好的那种,方式多种,可操作性极强。好是好,但我却找不到了(一直在收藏都没停下来沉淀整理,待到用时难觅其踪)。无法可想,依据些许记忆和所学基础知识,鼓捣出了一个递归降维的土法。看起来“没毛病”,连我看都看不明白的“缠绕”数组都能捋清抹顺。
  我的思路是,遍历数组,元素是一维直接跳过,不是一维则降维。递归调用降维函数降维。
  经过对list对象试炼,发现str(llist)得到的字符串有“[]”。同理,元组和集合分别有“()”、“{}”。list(dict)只能得到一个key列表,这里不作探讨。

没有判断语句

        if ('(' in (s := str(i))) or ('{' in s):
            	i = list(i) #把元组或者集合的元素转成列表。

回页首

递归降维函数


def breaks(lis):
    ''' 递归降维函数。'''
    tem = [] # 降维后数组容器。
    for i in lis:

        if ('(' in (s := str(i))) or ('{' in s):
            	i = list(i) #把元组或者集合的元素转成列表。

        if '[' in str(i):
            tem.extend(breaks(i)) # 递归调用,返回的降维元素追加到降维存储容器。
        else:
            tem.append(i)

    tem.sort(key=lambda x: len(str(x))) # 数组正序(以元素组成字符个数排序)。
    return tem # 返回降维后的数组。


回页首

复杂“缠绕”数组降维

复杂“缠绕”数组

[1, [2, {‘9’, (3, 4), ‘A’}], ‘99’, 5, [6, ‘s’, 7], (8, 9), (10, ‘ok’, 11), 12, [(13, ‘数组降维’), 14], ‘Python’, 15, 16, {17, (18, ‘very nice’, 19), (‘ok’, 20, 21, 55), (‘ABC’, 22), 23}] # “复杂”的多维数组。

代码


print('\033[2J') # 清屏。
lis = [1, [2, {'9', (3, 4), 'A'}], '99', 5,  [6, 's', 7], (8, 9), (10, 'ok', 11), 12, [(13, '数组降维'), 14], 'Python', 15, 16, {17, (18, 'very nice', 19), ('ok', 20, 21, 55), ('ABC', 22), 23}] # “复杂”的多维数组。
print(f"\n原列表:{lis}\n\n降维后:{breaks(lis)}\n")

输出

原列表:[1, [2, {‘9’, (3, 4), ‘A’}], ‘99’, 5, [6, ‘s’, 7], (8, 9), (10, ‘ok’, 11), 12, [(13, ‘数组降维’), 14], ‘Python’, 15, 16, {17, (18, ‘very nice’, 19), 23, (‘ABC’, 22), (‘ok’, 20, 21, 55)}]

降维后:[1, 2, ‘9’, 3, 4, ‘A’, 5, 6, ‘s’, 7, 8, 9, ‘99’, 10, ‘ok’, 11, 12, 13, 14, 15, 16, 17, 18, 19, 23, 22, ‘ok’, 20, 21, 55, ‘ABC’, ‘数组降维’, ‘Python’, ‘very nice’]

输出截屏图片
在这里插入图片描述


回页首

相对简单的数组降维试炼

[66, {67, 68, (69, 70, 71)}, [72, 73, {74, 75}, (76, 77)]]

代码


lis2 = [66, {67, 68, (69, 70, 71)}, [72, 73, {74, 75}, (76, 77)]]
print(f"\n原列表:{lis2}\n\n降维后:{breaks(lis2)}\n")

输出

原列表:[66, {67, 68, (69, 70, 71)}, [72, 73, {74, 75}, (76, 77)]]

降维后:[66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77]

输出截屏图片(简单的数组)
在这里插入图片描述


回页首

mypycolor完整源码(源码较长,点此跳过源码)

def breaks(lis):
    ''' 递归降维函数。'''
    tem = [] # 降维后数组容器。
    for i in lis:

        if ('(' in (s := str(i))) or ('{' in s):
            	i = list(i) #把元组或者集合的元素转成列表。

        if '[' in str(i):
            tem.extend(breaks(i)) # 递归调用,返回的降维元素追加到降维存储容器。
        else:
            tem.append(i)

    tem.sort(key=lambda x: len(str(x))) # 数组正序(以元素组成字符个数排序)。
    return tem # 返回降维后的数组。


print('\033[2J') # 清屏。
lis = [1, [2, {'9', (3, 4), 'A'}], '99', 5,  [6, 's', 7], (8, 9), (10, 'ok', 11), 12, [(13, '数组降维'), 14], 'Python', 15, 16, {17, (18, 'very nice', 19), ('ok', 20, 21, 55), ('ABC', 22), 23}] # “复杂”的多维数组。
print(f"\n原列表:{lis}\n\n降维后:{breaks(lis)}\n")

lis2 = [66, {67, 68, (69, 70, 71)}, [72, 73, {74, 75}, (76, 77)]]
print(f"\n原列表:{lis2}\n\n降维后:{breaks(lis2)}\n")

回页首

__上一篇:__ 升级迭代:让mypycolor变得聪明

__下一篇:__ 

我的HOT博:

    本文含有隐藏内容,请 开通VIP 后查看

    网站公告

    今日签到

    点亮在社区的每一天
    去签到