zoukankan      html  css  js  c++  java
  • 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":
              m += 1
          if m == 2:    # 当"a"第二次出现时, 打印此时循环到的列表位置(下标)
              print(n)
              break
          n += 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)
      
    5. 列表推导式

      # 定义列表
      l = ["a", "b", "c", "a", "b", "c", "a"]
      # 定义通用的获取某元素在列表中第n次出现的位置下标的函数
      def get_index(l, x, n):
          if n <= l.count(x):
              all_index = [key for key, value in enumerate(l) if value == x]
              return all_index[n-1]
          else:
              return None
      # 调用函数, 获取结果
      result_l = get_index(l, "a", 2)
      print(result_l)
      
  • 相关阅读:
    Linux下安装配置词典GoldenDict
    ubuntu 安装LaTex
    ubuntu 安装Opencv2.4.7
    Ubuntu 安装Matlab2010a
    Ubuntu 挂载ISO文件的方法
    ubuntu安装Java jdk1.7.0
    VDI转vmdk(VirtualBox与VMware硬盘格式转换)[转]
    oracle忘记密码,修改密码,解锁
    SQL Server 2008中文企业版下载地址和序列号[转]
    HTTP 错误 500.19 – Internal Server Error web.config 文件的 system.webServer/httpErrors 节中不允许绝对物理路径“C:inetpubcusterr”[转]
  • 原文地址:https://www.cnblogs.com/hellomrr/p/10696011.html
Copyright © 2011-2022 走看看