一、简介

数据结构是通过某种方式组织在一起的数据元素的集合。

序列是python中最基本的数据结构,python中包含6种内建的序列,分别是列表、元组、字符串、Unicode字符串、buffer对象和xrange对象。

二、使用

比如说现在想用一个列表存储用户的名称和年龄,可以在python中创建列表:

dotgua = ['dotgua', 24]

这里非常像是一个数组,不过这里可以看到列表中可以存放不同的数据类型。

通用序列操作

序列的基本操作包括:索引(indexing)、分片(slicing)、加(adding)、乘(multiplying)以及成员检查,以下都以列表为例

√ 索引

序列可以根据元素的编号访问--从0开始递增,例如:

>>> dotgua = ['dotgua', 24]
>>> dotgua[0]
'dotgua'

索引也可以是负数,使用负数时python会从右边向左计数:

>>> dotgua[-1]
24

字符串本身也可以看做是列表:

>>> 'dotgua'[2]
't'

下面是一个示例程序,根据输入的年月日输出相应的日期的月份名称

#!/usr/bin/env python
# 根据给定的年月日以数字形式打印出日期
months = [
'January',
'February',
'March',
'April',
'May',
'June',
'July',
'August',
'September',
'October',
'November',
'December'
] # 以1~31的数字作为结尾的列表
endings = ['st', 'nd', 'rd'] + 17 * ['th'] + \
['st', 'nd', 'rd'] + 7 * ['th'] + ['st'] year = input('Year: ')
month = input('Month(1-12): ')
day = input('Day(1-31): ') month_number = int(month)
day_number = int(day) # 将月份和天数减1获得正确的索引
month_name = months[month_number-1]
ordinal = day + endings[day_number-1] print(month_name + ' ' + ordinal + ', ' + year)

√ 分片

分片用来访问一定范围内的元素。通过冒号隔开的两个索引实现

>>> numbers = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
>>> numbers[2:4]
[2, 3]

可以看到,第一个索引指定开始元素的索引,第二个则是最后一个元素的下一个位置的索引

分片也可以使用负数,负数即是从后向前计数

>>> numbers[-3:-1]
[7, 8]

但是可以发现,这样没法取得最后一个元素,如果想取得最后一个元素,省略第二个索引即可

>>> numbers[-3:]
[7, 8, 9]

同理,第一个索引也可以省略,即从第一个元素到第二个索引指定的元素

>>> numbers[:3]
[0, 1, 2]

甚至,两个索引都可以省略,即获取整个列表,这在复制列表时比较有用

>>> numbers[:]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

分片还可以设置步长:

>>> numbers[0:10:2]
[0, 2, 4, 6, 8]

步长也可以为负数:

>>> numbers[10:0:-3]
[9, 6, 3]

√ 序列相加

>>> [1, 2, 3] + [4, 5, 6]
[1, 2, 3, 4, 5, 6]

√ 序列乘法

>>> 'python' * 5
'pythonpythonpythonpythonpython'
>>> [4] * 10
[4, 4, 4, 4, 4, 4, 4, 4, 4, 4]

用None来初始化列表,None表示什么都没有

>>> seq = [None]*10
>>> seq
[None, None, None, None, None, None, None, None, None, None]

√ 成员资格

检查一个元素是否在序列中可以使用in运算符

>>> 5 in numbers
True

以下的示例模仿检查用户名密码是否正确:

database = [
['dotgua', '1234'],
['dotdai', '4567'],
]
username = input('User name: ')
password = input('password: ')
if [username, password] in database:
print('Access granted')
else:
print('Not granted')

√ 长度、最大值和最小值

len()返回序列的长度

max()返回序列的最大值

min()返回序列的最小值

>>> len(numbers)
10
>>> max(numbers)
9
>>> min(numbers)
0

三、列表

1. list函数

list函数可以将字符串转化为单个字符的列表:

>>> list('dotgua')
['d', 'o', 't', 'g', 'u', 'a']

join可以执行相反操作:

''.join(['d', 'o', 't', 'g', 'u', 'a'])

2. 基本操作

元素赋值

根据索引即可修改

删除元素

使用del关键字删除某个位置的元素

>>> del numbers[2]
>>> numbers
[0, 1, 3, 4, 5, 6, 7, 8, 9]

分片赋值

分片操作可以一次赋值或添加多个元素

>>> numbers = [1, 2, 3]
>>> numbers[3:] = [4, 5, 6]
>>> numbers
[1, 2, 3, 4, 5, 6]

也可以在添加元素的同时删除元素

>>> numbers = [1, 2, 3]
>>> numbers[1:] = [4, 5, 6]
>>> numbers
[1, 4, 5, 6]

或者只删除元素

>>> numbers[1:] = []
>>> numbers
[1]

3. 列表方法

append

追加新元素

count

统计某个元素出现的次数

extend

追加另一个序列

index

找到第一个匹配项的位置

insert

将元素插入到列表中

pop

移除列表中的一个元素(默认是最后一个)

remove

python学习笔记02--列表和元组的更多相关文章

  1. python学习笔记之列表与元组

    一.概述 python包含6种内建的序列,其中列表和元组是最常用的两种类型.列表和元组的主要区别在于,列表可以修改,元组则不能修改 使用上,如果要根据要求来添加元素,应当使用列表:而由于要求序列不可修 ...

  2. Python学习笔记_week2_列表、元组、字典、字符串、文件、i编码

    一. 列表.元组 names=["A","B","C","D"] print(names) print(names[0] ...

  3. python学习笔记(2)--列表、元组、字符串、字典、集合、文件、字符编码

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1.列表和元组的操作 列表是我们以后最长用的数据类型之一,通过列表可以最方便的对数据实现最方便的存储.修改等操作 定 ...

  4. python学习笔记(列表、元组、购物车实例)

    一.列表 列表和字典是最常用的两种数据类型 1. 需求:怎么存放班级80多人的姓名,如何实现? names = ["Zhangyang","Guyun",&qu ...

  5. Python学习笔记只列表和元组

    一.成员资格 1.检查某个字符是否在某个字符串中:'a' in 'absent' 2.获取数组的长度.最大.最小值: numbers=[100,54,345] len(numbers) //长度 ma ...

  6. python学习笔记整理——列表

    Python 文档学习笔记 数据结构--列表 列表的方法 添加 list.append(x) 添加元素 添加一个元素到列表的末尾:相当于a[len(a):] = [x] list.extend(L) ...

  7. 【python学习笔记02】python的数据类型2

    列表和元组之间的主要区别是:列表括在括号([])和它们的元素和大小是可以改变的,而元组在圆括号(),不能被更新.元组可以被认为是只读列表. 存储在一个列表中的值可以使用切片操作符来访问([]和[:]) ...

  8. python学习笔记-02

    四.函数 1.定义函数 (1)定义规则 介绍列表方法的时候已经大概说过函数,学过数学的人都知道函数,给一个参数返回一个值.函数也可以自己定义.用如下的格式: >>>def 函数名(参 ...

  9. python学习笔记(一)元组tuple

    元组由简单的对象组构成,元组与列表相似,但是元组不能在原处修改.元组位置有序的对象集合,元组通过偏移来访问. 为什么有了列表还要元组?元组的不变性提供了某种完整性,可以确保元组在程序中不被另一个引用修 ...

随机推荐

  1. 在JSP页面获取集合的长度

    在jsp页面上经常遇到得到集合长度.字符长度.字符切取等应用需,在2.0以前这种需是许多程序员对JSTL及为不满意的地方之一.为此在2.0 中添加了functions标签,其提供对以上需求的支持. 使 ...

  2. 1-JRE与JDK等知识

  3. LOJ-10103(求删去割点后最多的连通分量)

    题目链接:传送门 思路: (1)这道题的图可能不连通,所以需要多次Tarjan: (2)设置cut[i]=x数组表示第i个节点被删除后右多少个子图(这个只是在一个图中),如果是根节点就要-1,因为根节 ...

  4. 容器启动脚本报错:exec user process caused "no such file or directory"

    1.现象 standard_init_linux.go:: exec user process caused "no such file or directory" 2.原因 原因 ...

  5. Visual Studio中xml文件使用app.config、web.config等的智能提示的方法

    在.Net开发的过程中,有时我们需要使用Xml文件作为配置文件(基于某些情况的考虑),而不是app.config.web.config这种,但是我们在xml中配置时希望可以增加类似编辑app.conf ...

  6. PICE(6):集群环境里多异类端点gRPC Streaming - Heterogeneous multi-endpoints gRPC streaming

    gRPC Streaming的操作对象由服务端和客户端组成.在一个包含了多个不同服务的集群环境中可能需要从一个服务里调用另一个服务端提供的服务.这时调用服务端又成为了提供服务端的客户端了(服务消费端) ...

  7. 14:IO之字符字节流

    字节流: InputStream     OutputStream  字节流:  FileInputStream FileOutputStream BufferedInputStream Buffer ...

  8. MySQL 数据类型说明解释

    在 MySQL 中,有三种主要的类型:Text(文本).Number(数字)和 Date/Time(日期/时间)类型. Text 类型: 数据类型 描述 CHAR(size) 保存固定长度的字符串(可 ...

  9. Jedis 操作 Redis 工具类

    配置类 pom.xml pom.xml 里配置依赖 <dependency> <groupId>redis.clients</groupId> <artifa ...

  10. vsftpd安装配置以及常见问题解决

    vsftpd安装配置以及踩坑解决办法,Centos7 nginx已经配置成功了,但是使用http始终没办法访问到图片,那么你来对地方了(在文章末尾是原因) 配置nginx教程:http://blog. ...