小白学 Python(9):基础数据结构(列表)(上)
人生苦短,我选Python
前文传送门
前言
在开始今天的内容之前先简单介绍一下 Python 内置的数据结构,包括:
- 列表(list)
- 元组(tuple)
- 字典(dict)
- 集合(set)
在Python语言中,以上4种数据结构和基础数据类型(整数、浮点数等)统称为“内置类型”(Built-in Types)。
列表(list)
Python list(列表),是Python中最常用的一种数据结构,它是一组用方括号括起来、逗号分隔的数据。
创建列表:
list1 = [1, 2, 3, 4, 5]
print(list1)
list2 = ['a', 'b', 'c', 'd', 'e']
print(list2)
输出结果:
[1, 2, 3, 4, 5]
['a', 'b', 'c', 'd', 'e']
列表中的数据类型可以是相同的,如上面的 int 和 str ,也可以是不同的:
list3 = [1, 2, 3, 'a', 'b']
print(list3)
结果如下:
[1, 2, 3, 'a', 'b']
这个还不算什么,还有更骚的操作,列表里面是可以嵌套列表的:
list4 = [1, 2.33, 'a', list3]
print(list4)
结果如下:
[1, 2.33, 'a', [1, 2, 3, 'a', 'b']]
这一层一层的,又让我想起了洋葱。。。
空列表
list5 = []
print(list5)
列表的一些基操
查看列表的类型
查看类型的函数是 type()
,那么如果我们看下列表的类型呢?
print(type(list4))
结果如下:
<class 'list'>
通过索引取出列表的元素
语法:列表名[索引]
list1 = [1, 2, 3, 4, 5]
print(list1[0])
这里的数字 0 是列表的索引,含义是取出第 0 位的元素。
注意: 这里的索引是从 0 开始的,例如 list1 的索引是 0 ~ 4 。
如果我们直接去取 list1 的索引为 5 的值:
list1 = [1, 2, 3, 4, 5]
print(list1[5])
这时会直接抛出异常。
Traceback (most recent call last):
File "F:/project/python-learning/base-data-list/Demo.py", line 20, in <module>
print(list1[5])
IndexError: list index out of range
这个异常的含义是:列表索引超出范围。
Python 列表除了正索引还有一个负索引,正索引是列表从头到尾的方向,负索引的是从尾到头。
列表: ['a', 'b', 'c', 'd', 'e']
| | | | |
正索引: 0 1 2 3 4
负索引: -5 -4 -3 -2 -1
使用加号连接列表
语法: 列表1 + 列表2
print(list1 + list2)
结果如下:
[1, 2, 3, 4, 5, 'a', 'b', 'c', 'd', 'e']
对列表元素进行 for 循环
语法:
for 变量 in 列表:
print(变量)
for i in list1:
print(i)
结果如下:
1
2
3
4
5
获取列表长度
语法: len(列表)
print(len(list1))
print(len(list1 + list2))
结果如下:
5
10
检查列表中是否存在某个元素
返回的是布尔值 bool 。
print('a' in list1)
print(1 in list1)
结果如下:
False
True
删除列表
语法: del 列表名
list1 = [1, 2, 3, 4, 5]
del list1
print(list1)
结果如下:
Traceback (most recent call last):
File "D:/Development/Projects/python-learning/base-data-list/Demo.py", line 40, in <module>
print(list1)
NameError: name 'list1' is not defined
很显然,将 list1 删除之后会报错 list1 未定义。
删除列表中索引为 i 的元素
语法: del list1[i]
list1 = [1, 2, 3, 4, 5]
del list1[2]
print(list1)
结果如下:
[1, 2, 4, 5]
返回列表中最大的值
语法:max(list1)
print(list1)
print(max(list1))
print(list4)
print(max(list4))
结果如下:
[1, 2, 4, 5]
5
[1, 2.33, 'a', [1, 2, 3, 'a', 'b']]
Traceback (most recent call last):
File "D:/Development/Projects/python-learning/base-data-list/Demo.py", line 51, in <module>
print(max(list4))
TypeError: '>' not supported between instances of 'str' and 'float'
list4 中取最大值报错了,报错原因是 'str' 和 'float' 无法比较大小。
返回列表中最小的值
语法:min(list1)
print(list1)
print(min(list1))
print(list4)
print(min(list4))
结果如下:
[1, 2, 4, 5]
1
[1, 2.33, 'a', [1, 2, 3, 'a', 'b']]
Traceback (most recent call last):
File "D:/Development/Projects/python-learning/base-data-list/Demo.py", line 51, in <module>
print(max(list4))
TypeError: '<' not supported between instances of 'str' and 'float'
list4 中取最小值报错了,报错原因和上面取最大是一样的, 'str' 和 'float' 无法比较大小。
示例代码
本系列的所有代码小编都会放在代码管理仓库 Github 和 Gitee 上,方便大家取用。
小白学 Python(9):基础数据结构(列表)(上)的更多相关文章
- 小白学 Python(10):基础数据结构(列表)(下)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(12):基础数据结构(字典)(上)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(14):基础数据结构(集合)(上)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(11):基础数据结构(元组)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(13):基础数据结构(字典)(下)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(15):基础数据结构(集合)(下)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(16):基础数据类型(函数)(上)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(23):Excel 基础操作(上)
人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...
- 小白学 Python(2):基础数据类型(上)
人生苦短,我选Python 引言 前文传送门 小白学 Python(1):开篇 接触一门新的语言,肯定要先了解它的基础数据类型.啥?你问我为啥要先了解基础数据类型? 为了你的生命安全,还是乖乖听我 B ...
随机推荐
- 快速开始使用spark
1.版本说明 在spark2.0版本以前,spakr编程接口是RDD(Resilient Distributed Dataset,弹性分布式数据集),spark2.0版本即以上,RDD被Dataset ...
- Java线程池基础
目录: 一.线程池概述 二.线程池参数 三.线程池的执行过程 四.线程池的主要实现 五.线程池的使用 六.线程池的正确关闭方式 七.线程池参数调优 一.线程池概述 1.线程池类 目前线程池类一般有两个 ...
- 09.Django基础七之Ajax
一 Ajax简介 1.简介 AJAX(Asynchronous Javascript And XML)翻译成中文就是"异步的Javascript和XML".即使用Javascrip ...
- springboot 启动报错Consider defining a bean of type 'com.example.springbootdruid.mapper.UserMapper' in your configurati
一.问题 springboot项目启动时报错: Field userMapper in com.example.springbootdruid.service.impl.UserServiceImpl ...
- SUSE CaaS Platform 4 - 简介
SUSE CaaS Platform KUBERNETES - 面向企业 SUSE CaaS Platform 是一款企业级容器管理解决方案,可让 IT 和 DevOps 专业人士更轻松地部署.管理和 ...
- layload.js的使用
网上有人反映说lazyload只是效果好看并没有实现真正的懒加载,在后台仍然是把页面上的所有图片下了一遍,只不过是先把图片隐藏并在窗口向下滚动时再逐一显示出来罢了.lazyloag3经测试这个问题已经 ...
- python Django中的cookie和session
目录 Cookie 1.1获取Cookie 1.2设置Cookie Session 1.数据库Session 2.缓存Session 3.文件Session 4.缓存+数据库Session Cooki ...
- Vim升华之树形目录插件NERDTree安装图解(ubuntu)
此文经验证:为真 http://www.linuxidc.com/Linux/2013-06/86048.htm
- pycharm导入自己写的包的时候,不能识别模块的解决办法
今天用写selenium脚本的时候导入自己统计目录下的模块时,出错,明明存在但是报错说模块不存在,找了半天终于找到解决方案,顺便记录一下吧 pycharm不会将当前文件目录自动加入自己的sourse_ ...
- Spring Cloud Feign 性能优化
#### 1.替换 tomcat 首先,把 tomcat 换成 undertow,这个性能在 Jmeter 的压测下,undertow 比 tomcat 高一倍 **第一步,pom 修改去除tomca ...