首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何迭代嵌套列表,在搜索索引值之前打印索引值

迭代嵌套列表并在搜索索引值之前打印索引值的方法可以通过递归实现。下面是一个示例代码:

代码语言:txt
复制
def print_nested_list(nested_list, index=''):
    for i, item in enumerate(nested_list):
        if isinstance(item, list):
            print_nested_list(item, index + str(i) + '.')
        else:
            print(index + str(i) + '.', item)

# 示例嵌套列表
nested_list = [1, [2, 3, [4, 5]], 6, [7, [8, 9, [10]]]]

# 调用函数打印索引值和列表项
print_nested_list(nested_list)

输出结果如下:

代码语言:txt
复制
0. 1
1.0. 2
1.1. 3
1.2.0. 4
1.2.1. 5
2. 6
3.0. 7
3.1.0. 8
3.1.1. 9
3.1.2.0. 10

在这个示例中,我们定义了一个名为print_nested_list的函数,它接受一个嵌套列表作为输入参数,并使用递归的方式遍历列表中的每个元素。如果遍历到的元素是一个列表,则递归调用print_nested_list函数处理该子列表。如果遍历到的元素是一个普通的项,则打印索引值和该项的值。

这种方法可以处理任意层级的嵌套列表,并在每个项之前打印出对应的索引值。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • tf.while_loop

    cond是一个返回布尔标量张量的可调用的张量。body是一个可调用的变量,返回一个(可能是嵌套的)元组、命名元组或一个与loop_vars具有相同特性(长度和结构)和类型的张量列表。loop_vars是一个(可能是嵌套的)元组、命名元组或张量列表,它同时传递给cond和body。cond和body都接受与loop_vars一样多的参数。除了常规张量或索引片之外,主体还可以接受和返回TensorArray对象。TensorArray对象的流将在循环之间和梯度计算期间适当地转发。注意while循环只调用cond和body一次(在调用while循环的内部调用,而在Session.run()期间根本不调用)。while loop使用一些额外的图形节点将cond和body调用期间创建的图形片段拼接在一起,创建一个图形流,该流重复body,直到cond返回false。为了保证正确性,tf.while循环()严格地对循环变量强制执行形状不变量。形状不变量是一个(可能是部分的)形状,它在循环的迭代过程中保持不变。如果循环变量的形状在迭代后被确定为比其形状不变量更一般或与之不相容,则会引发错误。例如,[11,None]的形状比[11,17]的形状更通用,而且[11,21]与[11,17]不兼容。默认情况下(如果参数shape_constant没有指定),假定loop_vars中的每个张量的初始形状在每次迭代中都是相同的。shape_constant参数允许调用者为每个循环变量指定一个不太特定的形状变量,如果形状在迭代之间发生变化,则需要使用该变量。tf.Tensor。体函数中也可以使用set_shape函数来指示输出循环变量具有特定的形状。稀疏张量和转位切片的形状不变式特别处理如下:

    04

    Python学习笔记整理 Pytho

    一、字典介绍 字典(dictionary)是除列表意外python之中最灵活的内置数据结构类型。列表是有序的对象结合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。 1、字典的主要属性 *通过键而不是偏移量来读取 字典有时称为关联数组或者哈希表。它们通过键将一系列值联系起来,这样就可以使用键从字典中取出一项。如果列表一样可以使用索引操作从字典中获取内容。 *任意对象的无序集合 与列表不同,保存在字典中的项并没有特定的顺序。实际上,Python将各项从左到右随机排序,以便快速查找。键提供了字典中项的象征性位置(而非物理性的)。 *可变,异构,任意嵌套 与列表相似,字典可以在原处增长或是缩短(无需生成一份拷贝),可以包含任何类型的对象,支持任意深度的嵌套,可以包含列表和其他字典等。 *属于可变映射类型 通过给索引赋值,字典可以在原处修改。但不支持用于字符串和列表中的序列操作。因为字典是无序集合,根据固定顺序进行操作是行不通的(例如合并和分片操作)。字典是唯一内置的映射类型(键映射到值得对象)。 *对象引用表(哈希表) 如果说列表是支持位置读取对象的引用数组,那么字典就是支持键读取无序对象的引用表。从本质上讲,字典是作为哈希表(支持快速检索的数据结构)来实现的。一开始很小,并根据要求而增长。此外,Python采用最优化的哈希算法来寻找键,因此搜索是很快速的。和列表一样字典存储的是对象引用。 2、常见的字典操作 可以查看库手册或者运行dir(dict)或者help(dict),类型名为dict。当写成常量表达式时,字典以一系列"键:值(key:value)”对形式写出的,用逗号隔开,用大括号括起来。可以和列表和元组嵌套 操作                        解释 D1={}                        空字典 D={'one':1}                    增加数据 D1[key]='class'                    增加数据:已经存在就是修改,没有存在就是增加数据 D2={'name':'diege','age':18}            两项目字典 D3={'name':{'first':'diege','last':'wang'},'age':18} 嵌套 D2['name']                    以键进行索引计算 D3['name']['last']                字典嵌套字典的键索引 D['three'][0]                    字典嵌套列表的键索引 D['six'][1]                    字典嵌套元组的键索引 D2.has_key('name')                 方法:判断字典是否有name键 D2.keys()                    方法:键列表 list(D)                        获取D这个字典的的KEY的 MS按字典顺序排序成一个列表 D2.values()                      方法:值列表 'name' in D2                    方法:成员测试:注意使用key来测试 D2.copy()                     方法:拷贝 D2.get(key,deault)                方法:默认 如果key存在就返回key的value,如果不存在就设置key的value为default。但是没有改变原对象的数据 D2.update(D1)                    方法:合并。D1合并到D2,D1没有变化,D2变化。注意和字符串,列表好的合并操作”+“不同 D2.pop('age')                    方法:删除 根据key删除,并返回删除的value len(D2)                        方法:求长(存储元素的数目) D1[key]='class'                    方法:增加:已经存在的数据就是修改,没有存在就是增加数据 D4=dict(name='diege',age=18)            其他构造技术 D5=dict.fromkeys(['a','b'])                 其他构造技术 dict.fromkeys 可以从一个列表读取字典的key 值默认为空,可指定初始值.两个参数一个是KEY列表,一个初始值 >>> D4 {'a': None, 'b': None} >>> D5=dict.fromkeys(['a

    01

    Python基本手册

    type() #查看类型 dir() help() len() open() #文本文件的输入输出 range() enumerate() zip() #循环相关 iter() #循环对象 map() filter() reduce() #函数对象 abs(-2) #取绝对值 round(2.3) #取整 pow(3,2) #乘方 cmp(3.1, 3.2) #比较大小 divmod(9, 7) #返回除法的结果和余数 max([2, 4, 6, 8]) #求最大值 min([1, 2, -1, -2]) #求最小值 sum([-1, 1, 5, 7]) #求和 int(“10”) #字符转为整数 float(4) #转为浮点数 long(“17”) # 转为长整数 str(3.5) #转为字符串 complex(2, 5) #返回复数2 + 5i ord(“A”) #A对应的ascii码 chr(65) #ascii码对应的字符 unichr(65) #数值65对应的unicode字符 bool(0) #转换为相应的真假值,0相当于False btw:”空” 值相当于False:[],(),{},0,None,0.0 all([True, 2, “wow!”]) #是否所有元素相当于True,全为True则为True any([0, “”, False, [], None]) #是否有元素相当于True sorted([1, 7, 4]) #序列升序排序 reversed([1, 5, 3]) #序列降序排序 list((1, 2, 3)) #tuple转换为表list tuple([4, 5, 4]) #list转换为tuple dict(a=3, b=”hi”, c=[1,2,3]) #构建字典 d = dict(a=3, b=”hi”, c=[1,2,3]) #d则为字典,字典的引用方式d[“a”]的值为3 input(‘input something’) #等待用户输入 globals() #返回全局变量名,函数名 locals() #返回局部命名空间

    05
    领券