热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python3学习笔记-列表(list)

Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。注:列表、list、数组、array是一个东西,只是叫法不一样列表的索引(下标)从0

Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。

注:列表、list、数组、array 是一个东西,只是叫法不一样

列表的索引(下标)从0开始,最后一个可以用-1表示

cities=['广州', '南京', '上海', '深圳', '厦门', '成都']  # 定义一个列表
print(cities)
#cities打印结果为:['广州', '南京', '上海', '深圳', '厦门', '成都']

 变量cities就是一个list。用len()函数可以获得list元素的个数:

cities=['广州', '南京', '上海', '深圳', '厦门', '成都']  # 定义一个列表
print(len(cities))
# 打印结果为:6

1、for循环

for 循环在循环可迭代对象的时候,每次循环的是里面的每一个元素。即如果直接for 循环一个list 时,那么每次循环的都是这个List里的元素

cities=['广州', '南京', '上海', '深圳', '厦门', '成都']  # 定义一个列表
for city in cities: 
print(city)

返回结果:

广州
南京
上海
深圳
厦门
成都

2、增加

  append()在列表末尾增加一个元素

  insert()插入,可指定的位置增加元素

cities=['广州', '南京']  # 定义一个列表
cities.append('北京')   #append在list末尾增加一个元素
print (cities)
cities.insert(0,'福州')  #insert插入,在下标为0处增加一个元素
print (cities)
cities.insert(20,'上海') #insert插入,如果指定的下标不存在,那么就在末尾添加一个新元素
print (cities)
cities.insert(-1,'杭州') #insert插入,在末尾(下标为-1处)添加一个新元素
print (cities)

上面代码打印结果为:

['广州', '南京', '北京']
['福州', '广州', '南京', '北京']
['福州', '广州', '南京', '北京', '上海']
['福州', '广州', '南京', '北京', '杭州', '上海']

3、删除

  pop() 删除指定的位置增加元素,传的是下标

  remove() 删除指定的元素,传的是元素

  del 删除指定位置的元素

  clear() 清空list

cities=['福州', '广州', '南京', '北京', '杭州', '上海'] # 定义一个列表
cities.pop(0)  #删除指定位置的元素,传的是下标
print (cities)
cities.remove('北京')   #删除指定的元素,传的是元素
print (cities)
del cities[-1]    # 删除指定位置的元素
print (cities)
cities.clear()    #清空list
print (cities)

上面代码打印结果为:

['广州', '南京', '北京', '杭州', '上海']
['广州', '南京', '杭州', '上海']
['广州', '南京', '杭州']
[]

4、修改

  指定下标修改,如果指定的下标不存在,会报错

cities=['福州', '广州', '南京', '北京', '杭州', '上海'] # 定义一个列表
cities[1]='南昌'   # 指定下标修改
print(cities)
cities[20]='长沙'   # 修改的时候如果指定的下标不存在,会报错
print(cities)

上面代码打印结果为:

['福州', '南昌', '南京', '北京', '杭州', '上海']
Traceback (most recent call last):
  File "F:/21.py", line 4, in 
    cities[20]='长沙'   # 修改的时候如果指定的下标不存在,会报错
IndexError: list assignment index out of range

5、查看

  指定下标查看

  index() 获取元素的下标,如果找不到那个元素的话未报错

  count() 查看元素在列表里面出现的次数

  reverse() 把列表反转过来

cities=['福州', '广州', '南京', '广州', '北京', '上海'] # 定义一个列表
print(cities[0])  #指定位置的
print(cities.index('北京'))   #获取元素的下标,如果找不到那个元素的话未报错
print (cities.count('广州'))   #查看元素在list里面出现多少次
cities.reverse() # 就是把这个list反转一下
print (cities)

上面代码打印结果为:

福州
4
2
['上海', '北京', '广州', '南京', '广州', '福州']

6、排序

  sort() 默认升序,如果参数reverse=True时,为降序

nums1=['b','f','z','e','g','h','n']
nums1.sort()  #排序,升序
print (nums1)
nums1.sort(reverse=True)  #排序,降序
print (nums1)

上面代码打印结果为:

['b', 'e', 'f', 'g', 'h', 'n', 'z']
['z', 'n', 'h', 'g', 'f', 'e', 'b']

7、合并列表

  + 可合并两个列表中的元素

  *N 与字符串类似,可将列表中的元素重复N次

cities=['福州', '广州']
cities2=['深圳','厦门','成都']
print (cities+cities2)   # + 可以合并list
print(cities*2)
print('哈哈哈'*3)

上面代码打印结果为:

['福州', '广州', '深圳', '厦门', '成都']
['福州', '广州', '福州', '广州']
哈哈哈哈哈哈哈哈哈

 


推荐阅读
  • 本指南从零开始介绍Scala编程语言的基础知识,重点讲解了Scala解释器REPL(读取-求值-打印-循环)的使用方法。REPL是Scala开发中的重要工具,能够帮助初学者快速理解和实践Scala的基本语法和特性。通过详细的示例和练习,读者将能够熟练掌握Scala的基础概念和编程技巧。 ... [详细]
  • 使用 ListView 浏览安卓系统中的回收站文件 ... [详细]
  • 本文探讨了 Java 中 Pair 类的历史与现状。虽然 Java 标准库中没有内置的 Pair 类,但社区和第三方库提供了多种实现方式,如 Apache Commons 的 Pair 类和 JavaFX 的 javafx.util.Pair 类。这些实现为需要处理成对数据的开发者提供了便利。此外,文章还讨论了为何标准库未包含 Pair 类的原因,以及在现代 Java 开发中使用 Pair 类的最佳实践。 ... [详细]
  • 本课程深入探讨了 Python 中自定义序列类的实现方法,涵盖从基础概念到高级技巧的全面解析。通过实例演示,学员将掌握如何创建支持切片操作的自定义序列对象,并了解 `bisect` 模块在序列处理中的应用。适合希望提升 Python 编程技能的中高级开发者。 ... [详细]
  • 探索偶数次幂二项式系数的求和方法及其数学意义 ... [详细]
  • 本文深入解析了JDK 8中HashMap的源代码,重点探讨了put方法的工作机制及其内部参数的设定原理。HashMap允许键和值为null,但键为null的情况只能出现一次,因为null键在内部通过索引0进行存储。文章详细分析了capacity(容量)、size(大小)、loadFactor(加载因子)以及红黑树转换阈值的设定原则,帮助读者更好地理解HashMap的高效实现和性能优化策略。 ... [详细]
  • Python编程中条件控制下的循环终止机制详解 ... [详细]
  • 深入理解排序算法:集合 1(编程语言中的高效排序工具) ... [详细]
  • 本文探讨了一种高效的算法,用于生成所有数字(0-9)的六位组合,允许重复使用数字,并确保这些组合的和等于给定的整数N。该算法通过优化搜索策略,显著提高了计算效率,适用于大规模数据处理和组合优化问题。 ... [详细]
  • 每年,意甲、德甲、英超和西甲等各大足球联赛的赛程表都是球迷们关注的焦点。本文通过 Python 编程实现了一种生成赛程表的方法,该方法基于蛇形环算法。具体而言,将所有球队排列成两列的环形结构,左侧球队对阵右侧球队,首支队伍固定不动,其余队伍按顺时针方向循环移动,从而确保每场比赛不重复。此算法不仅高效,而且易于实现,为赛程安排提供了可靠的解决方案。 ... [详细]
  • Python进阶笔记:深入理解装饰器、生成器与迭代器的应用
    本文深入探讨了Python中的装饰器、生成器和迭代器的应用。装饰器本质上是一个函数,用于在不修改原函数代码和调用方式的前提下为其添加额外功能。实现装饰器需要掌握闭包、高阶函数等基础知识。生成器通过 `yield` 语句提供了一种高效生成和处理大量数据的方法,而迭代器则是一种可以逐个访问集合中元素的对象。文章详细解析了这些概念的原理和实际应用案例,帮助读者更好地理解和使用这些高级特性。 ... [详细]
  • 本文详细介绍了使用 Python 进行 MySQL 和 Redis 数据库操作的实战技巧。首先,针对 MySQL 数据库,通过 `pymysql` 模块展示了如何连接和操作数据库,包括建立连接、执行查询和更新等常见操作。接着,文章深入探讨了 Redis 的基本命令和高级功能,如键值存储、列表操作和事务处理。此外,还提供了多个实际案例,帮助读者更好地理解和应用这些技术。 ... [详细]
  • 【图像分类实战】利用DenseNet在PyTorch中实现秃头识别
    本文详细介绍了如何使用DenseNet模型在PyTorch框架下实现秃头识别。首先,文章概述了项目所需的库和全局参数设置。接着,对图像进行预处理并读取数据集。随后,构建并配置DenseNet模型,设置训练和验证流程。最后,通过测试阶段验证模型性能,并提供了完整的代码实现。本文不仅涵盖了技术细节,还提供了实用的操作指南,适合初学者和有经验的研究人员参考。 ... [详细]
  • 机器学习中的标准化缩放、最小-最大缩放及鲁棒缩放技术解析 ... [详细]
  • HBase Java API 进阶:过滤器详解与应用实例
    本文详细探讨了HBase 1.2.6版本中Java API的高级应用,重点介绍了过滤器的使用方法和实际案例。首先,文章对几种常见的HBase过滤器进行了概述,包括列前缀过滤器(ColumnPrefixFilter)和时间戳过滤器(TimestampsFilter)。此外,还详细讲解了分页过滤器(PageFilter)的实现原理及其在大数据查询中的应用场景。通过具体的代码示例,读者可以更好地理解和掌握这些过滤器的使用技巧,从而提高数据处理的效率和灵活性。 ... [详细]
author-avatar
苦蔷薇1988
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有