Python3列表中获取相同元素出现位置的下标
Posted Nonevx
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python3列表中获取相同元素出现位置的下标相关的知识,希望对你有一定的参考价值。
前言
list: Python3的列表类型, 和其他语言中的数组类似
定义格式:
l = ["a", "b", "c", "a", "b", "c", "a"]
, 下文举例用到的列表x为此列表list常用方法(文章中用到的方法):
index(元素[, Start[, Stop]]) : 获取列表下标
三个参数, 后两个参数为可选参数.
一个参数, PS:
l.index("a")
, 获取列表中第一个出现的"a"的下标, 此例获取结果为0
两个参数, PS:
l.index("a", 5)
, 获取列表片段中第一个出现的"a"对应的列表的下标, 是指从列表的下标为5处开始查找, 默认找到列表结尾, 此例获取结果为6
, 如果第二个参数为负数, 则下标位置从后往前数, 从-1开始, 例如最后一个"a"的位置就是-1, 第二个"c"的位置为-2三个参数, PS:
l.index("a", 2, 5)
, 获取列表片段中第一个出现的"a"对应的列表的下标, 是指从列表的下标为2处(包括2)开始查找, 找到列表下标为5处(不包括5), 此例获取结果为3
, 第三个参数为结束位置, 但不包含此位置count(元素): 获取元素在列表中的出现次数
PS:
l.count("a")
, 此例获取结果为3
Python内置函数
enumerate(iterable[, Start])
返回一个枚举对象, iterable必须是一个序列,或iterator,或其他支持迭代的对象. enumerate() 返回的迭代器的__next__() 方法返回一个元组,里面包含一个计数值(从 start 开始,默认为 0)和通过迭代 iterable 获得的值
需求
- PS: 获取列表x中第二个"a"出现的位置的下标
代码实现
破坏原有结构
# 定义列表 l = ["a", "b", "c", "a", "b", "c", "a"] # 获取第一个"a"的下标 index_one = l.index("a") # 删除第一个出现的"a"元素 l.pop(index_one) # 再次获取第一个"a"的下标(相当于原列表的第二个"a"), 因为列表删除过一个元素, 所以加1 print(l.index("a") + 1)
for循环
# 定义列表 l = ["a", "b", "c", "a", "b", "c", "a"] # 定义变量, 记录"a"出现次数 m = 0 # 定义变量, 记录循环到的列表位置, 相当于列表下标 n = 0 # 遍历列表 for i in l: if i == "a": n += 1 if n == 2: # 当"a"第二次出现时, 打印此时循环到的列表位置(下标) print(m) break m += 1
index方法
# 定义列表 l = ["a", "b", "c", "a", "b", "c", "a"] # 获取第一个"a"的下标 index_one = l.index("a") # 从第一个"a"的下一个位置开始查找, 所以加1 print(l.index("a", index_one + 1))
enumerate函数枚举(推荐)
# 定义列表 l = ["a", "b", "c", "a", "b", "c", "a"] # 定义通用的获取某元素在列表中第n次出现的位置下标的函数 def get_index(l, x, n): # 函数作用: 获取某个元素第n次出现在列表的下标 # 参数列表: 第一个参数为可迭代对象, 第二个参数为要查找的数, 第三个参数为要查找第几个出现的x l_count = l.count(x) result = None if n <= l_count: num = 0 for item in enumerate(l): if item[1] == x: num += 1 if num == n: result = item[0] break else: print("列表里总共有{}个{}".format(l_count, x)) return result # 调用函数, 获取结果 result_l = get_index(l, "a", 2) print(result_l)
以上是关于Python3列表中获取相同元素出现位置的下标的主要内容,如果未能解决你的问题,请参考以下文章