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"出现的位置的下标

代码实现

  1. 破坏原有结构

    # 定义列表
    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)
  2. 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
  3. index方法
    # 定义列表
    l = ["a", "b", "c", "a", "b", "c", "a"]
    # 获取第一个"a"的下标
    index_one = l.index("a")
    # 从第一个"a"的下一个位置开始查找, 所以加1
    print(l.index("a", index_one + 1))
  4. 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)

原文地址:https://www.cnblogs.com/hellomrr/p/10696011.html

时间: 2024-11-06 03:48:18

Python3列表中获取相同元素出现位置的下标的相关文章

C++11 —— 获取 tuple 参数列表中指定数据类型的索引位置

1. 问题背景 ??在 C++11 的标准中,我们可以通过 std::get< Index >(tuple) (以常量整数值为索引号)操作 tuple 中的参数,而到了 C++14 之后的标准,新增了 std::get< Type >(tuple) (以数据类型为索引)的方式操作 tuple 中的参数.那么,若只是在 C++11 标准中,是否有办法使用 以数据类型为索引 的方式操作 tuple 中的参数呢? 2. 解决办法 ??解决上面所提到的问题,其本质上,就是要解决 如何获取

JS中获取 DOM 元素的绝对位置实例详解

在操作页面滚动和动画时经常会获取 DOM 元素的绝对位置,例如 本文 左侧的悬浮导航,当页面滚动到它以前会正常地渲染到文档流中,当页面滚动超过了它的位置,就会始终悬浮在左侧. 本文会详述各种获取 DOM 元素绝对位置 的方法以及对应的兼容性.关于如何获取 DOM 元素高度和滚动高度,请参考视口的宽高与滚动高度 一文. 概述 这些是本文涉及的 API 对应的文档和标准,供查阅: API 用途 文档 标准 offsetTop 相对定位容器的位置 MDN CSSOM View Module clien

用Python实现剔除列表中相同的元素

问题描述:采用python实现剔除列表中相同的元素.顾名思义,比如说有一列表listVal = [12, 34, 23, 12, 23, 34, 15],经过剔除之后,应该只剩下listVal = [15]. 起初,我的思路是这样的:遍历每一个元素a(称之为大的遍历),记元素a的位序为LocA,对于每一个元素再做遍历(小的遍历),小的遍历中应该是这样执行的:在LocA直到列表结尾查找跟a相同的位序SameLocA,如果找到了,则删除找到的SameLocA对应的元素跟a;如果没找到,则遍历下一个元

[转载]用Javascript获取页面元素的位置

原文地址:http://www.ruanyifeng.com/blog/2009/09/find_element_s_position_using_javascript.html 制作网页的过程中,你有时候需要知道某个元素在网页上的确切位置. 下面的教程总结了Javascript在网页定位方面的相关知识. 一.网页的大小和浏览器窗口的大小 首先,要明确两个基本概念. 一张网页的全部面积,就是它的大小.通常情况下,网页的大小由内容和CSS样式表决定. 浏览器窗口的大小,则是指在浏览器窗口中看到的那

getBoundingClientRect() 来获取页面元素的位置

一.样式: ? 1 2 3 4 <style> body,div{ margin:0; padding:0} .div-info{ width:200px; height:200px;border:1px solid #ccc; background:#f2f2f2; font:normal 12px/22px SimSun; position:absolute;top:200px; left:200px} </style> 二.js ? 1 2 3 4 5 6 7 8 9 10

用getBoundingClientRect()来获取页面元素的位置

以前绝大多数的使用下面的代码来获取页面元素的位置: [code="javascript"]var _x = 0, _y = 0;do{_x += el.offsetLeft;_y += el.offsetTop;}while(el=el.offsetParent);return {x:_x,y:_y};[/code] 这里有个"offsetParent"问题,所以要写很多兼容的代码,经过不懈的查找终于找到getBoundingClientRect():该方法获得页面

Python List pop()方法-用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

描述 pop() 函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值. 语法 pop()方法语法: list.pop(obj=list[-1]) 参数 obj -- 可选参数,要移除列表元素的对象. 返回值 该方法返回从列表中移除的元素对象. 实例 以下实例展示了 pop()函数的使用方法: #!/usr/bin/python aList = [123, 'xyz', 'zara', 'abc']; print "A List : ", aList.pop(); pr

getBoundingClientRect()来获取页面元素的位置”

getBoundingClientRect()来获取页面元素的位置” 获取的是一个对象; 延伸阅读; https://mp.weixin.qq.com/s?__biz=MzAxODE2MjM1MA==&mid=403029188&idx=2&sn=1088e273b855b75815edb2e7977a0513&scene=0&key=710a5d99946419d988a823a3f76c4dabc336d68c1e192697aba3d5cdba0fce0f3d

交换数组中两个元素的位置,元素包括key和value 一维数组

/*author: [email protected]description: 交换数组中两个元素的位置,元素包括key和value,具体用法见下面的例子*/$arr = array(11=>'a',22=>'b',33=>'c',44=>'d');$res = array_exchange($arr, 11 ,33); //example:echo '<pre>';print_r ($res);echo '</pre>'; function array_e