当前位置: 首页 > news >正文

Python返回数组/List长度的方法

你想了解在 Python 中获取列表(List,也常被俗称 “数组”)长度的方法,这是 Python 基础中高频使用的操作,核心是通过内置函数实现,同时需要掌握不同场景下的使用细节(比如嵌套列表、numpy 数组等)。

一、核心方法:len()内置函数

Python 中获取列表长度的唯一标准且最高效的方法是使用内置函数len(),它适用于所有可迭代对象(列表、元组、字符串、字典等),语法简单且性能优异(时间复杂度 O (1),因为 Python 列表底层会维护长度属性,无需遍历计算)。

1. 基础用法示例

python

# 1. 普通列表的长度 nums = [1, 2, 3, 4, 5] length = len(nums) print(f"列表nums的长度:{length}") # 输出:列表nums的长度:5 # 2. 空列表的长度(返回0) empty_list = [] print(f"空列表的长度:{len(empty_list)}") # 输出:空列表的长度:0 # 3. 包含不同类型元素的列表 mix_list = [1, "Python", True, None, [6,7]] print(f"混合列表的长度:{len(mix_list)}") # 输出:混合列表的长度:5(每个元素算1个)
2. 嵌套列表的长度(关键注意点)

len()仅计算外层列表的元素个数,不会递归统计嵌套列表的所有元素总数:

python

# 嵌套列表 nested_list = [[1, 2, 3], [4, 5], [6]] # 外层长度:3(3个嵌套子列表) print(f"外层列表长度:{len(nested_list)}") # 输出:外层列表长度:3 # 如需统计所有嵌套元素的总数,需手动遍历/递归 total = 0 for sub_list in nested_list: total += len(sub_list) print(f"所有嵌套元素总数:{total}") # 输出:所有嵌套元素总数:6 # 递归统计任意深度嵌套列表的总元素数(进阶) def count_total_elements(lst): count = 0 for item in lst: if isinstance(item, list): count += count_total_elements(item) else: count += 1 return count deep_nested = [1, [2, [3, 4], 5], 6] print(f"深度嵌套总元素数:{count_total_elements(deep_nested)}") # 输出:6

二、特殊 “数组” 类型的长度获取

如果你口中的 “数组” 是指 Python 的第三方库(如 numpy)的数组(numpy.ndarray),len()仅返回第一维度的长度,需用专属方法:

python

# 先安装numpy:pip install numpy import numpy as np # numpy数组 np_array = np.array([[1,2,3], [4,5,6]]) # len()仅返回第一维度长度(2行) print(f"len()结果:{len(np_array)}") # 输出:2 # 获取完整形状(行数、列数):shape(返回元组) print(f"数组形状:{np_array.shape}") # 输出:(2, 3) # 获取总元素数:size print(f"总元素数:{np_array.size}") # 输出:6

三、常见注意事项

  1. 类型校验len()仅适用于可迭代对象(列表、字符串、元组等),对数字、None、布尔值等非可迭代对象使用会抛出TypeError,需提前校验:

    python

    # 错误示例:len(123) → 报错 TypeError: object of type 'int' has no len() # 安全写法 def safe_get_length(obj): try: return len(obj) except TypeError: print(f"错误:{obj} 不是可迭代对象,无长度属性") return None print(safe_get_length(123)) # 输出:错误:123 不是可迭代对象,无长度属性 → None print(safe_get_length([1,2])) # 输出:2
  2. 效率优势len()是 Python 内置的优化函数,直接读取列表的长度属性,比手动遍历计数(如count = 0; for i in lst: count +=1)快得多,无需自己实现计数逻辑。

总结

  1. Python 普通列表(List)的长度优先使用内置函数len(列表名),这是标准、高效的方式;
  2. len()对嵌套列表仅统计外层元素数,如需总元素数需手动遍历 / 递归;
  3. numpy 数组(ndarray)需用shape(维度)或size(总元素数),而非单纯依赖len()
http://www.jsqmd.com/news/145227/

相关文章:

  • 纯干货无广:基于真实体验的十大好用降AI工具红黑榜
  • 2025最新!研究生必备9个AI论文平台测评与推荐
  • 为了过知网检测,我自费测了十大降AI平台,最好用的都在这了
  • 如何开启第一次开源贡献之路?
  • 2025年儿童鞋服品牌前十名盘点:专业、舒适、潮流怎么选? - 品牌测评鉴赏家
  • 2026微信公众号服务号、订阅号、小程序、企业微信、微信开放平台、微信开发者平台区别
  • CSS定位的特殊应用
  • MySQL 创建数据库
  • IT监控:多场景探测+可视化诊断,实现网络故障快速排查
  • 国货之光!这10+国产儿童鞋服品牌闭眼入,宝妈收藏这篇就够了 - 品牌测评鉴赏家
  • DBeaver设置不断开连接
  • 国产三维设计软件 ZWPD vs 国外主流平台:协同效率与成本优势分析
  • 2025年国内儿童鞋服品牌前十名 综合排行榜(性价比 品质优选) - 品牌测评鉴赏家
  • Mozz TCAD丨晶体-器件坐标系的精准映射:MOZZ 各向异性模型的坐标配准方法
  • WebForms Controls:深入理解与高效应用
  • 学长血泪复盘:试错半个月,终于找到这十大靠谱降AI方法
  • AI Agent在心理健康领域的应用:情绪支持与干预
  • 2025年宝妈必看!中国十大童装品牌实力测评,从新生儿到学龄童全覆盖 - 品牌测评鉴赏家
  • 学长亲荐8个AI论文软件,专科生轻松搞定毕业论文!
  • PostgreSQL 时间/日期处理指南
  • 【社交APP上线记】小夏、老周、小林的讨论组
  • 年末财税稳控,让发票与收入成本“零隐患”
  • 为什么fastlio的frame_id是carmera_init
  • Doris资源组管理:精细化资源分配策略
  • 宝妈宝爸闭眼入!0 - 16岁儿童鞋服优质品牌大盘点 - 品牌测评鉴赏家
  • AI搜索重构流量格局,品牌如何制定下一代可见度战略?
  • 深入剖析CopyOnWriteArrayList:写时复制魔法让并发读取飞起来!
  • 别再交智商税了!盘点十大良心降AI工具,拒绝论文延毕
  • HTML 脚本:深入解析与实际应用
  • 隧道区域定位:黑暗中的“智慧灯塔”,筑牢地下空间安全防线