一、简介

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

序列是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. Html5与Css3知识点拾遗(六)

    web字号 px() 百分比(较常用) em(最常用):一般1em=16px,相对单位.以父元素作参照系,父元素大小是不确定的 body{ font-size:100%; /*父元素默认为16px*/ ...

  2. Codesmith怎么判断sqlserver数据库字段是不是标识自增字段

    Codesmith怎么判断sqlserver数据库字段是不是标识自增字段 使用ExtendedProperty扩展信息判断 CS_isIdentity:是否为标识符,不支持Access CS_isCo ...

  3. java 日志框架

    1.java常用日志框架介绍: https://www.cnblogs.com/chenhongliang/p/5312517.html 2.java各类日志组件汇总: https://blog.cs ...

  4. 用 Docker 构建、运行、发布来一个 Spring Boot 应用

    本文演示了如何用 Docker 构建.运行.发布来一个 Spring Boot 应用. Docker 简介 Docker 是一个 Linux 容器管理工具包,具备“社交”方面,允许用户发布容器的 im ...

  5. 【SP1811】 LCS - Longest Common Substring(SAM)

    传送门 洛谷 Solution 考虑他要求的是最长公共子串对吧,那么我们对于一个串建后缀自动机,另一个串在后缀自动机上面跑就是了. 复杂度\(O(n+m)\)的,很棒! 代码实现 代码戳这里

  6. Java 大数值类型执行精确计算

    简介 如果基本的整数和浮点数精度不能够满足需求,那么可以使用 java.math 包下两个很有用的类:BigInteger 和 BigDecimal.这两个类可以处理包含任意长度数字序列的数值,Big ...

  7. antd在webpack里面的配置

    概述 antd是蚂蚁金服打造的一个react组件,真的非常棒,我看了下官方文档,感觉比bootstrap要好.唯一的缺点可能就是打包的时候要打包它的一些样式表,所以资源体积会很大,并且css可能会和自 ...

  8. Postgresql日志收集

    PG安装完成后默认不会记录日志,必须修改对应的(${PGDATA}/postgresql.conf)配置才可以,这里只介绍常用的日志配置. 1.logging_collector = on/off   ...

  9. Spring 中初始化一个Bean对象时依赖其他Bean对象空指针异常

    1. Bean依赖关系 一个配置类的Bean,一个实例Bean: 实例Bean初始化时需要依赖配置类的Bean: 1.1 配置类Bean @ConfigurationProperties(prefix ...

  10. HDFS环境搭建(单节点配置)

    [参考文章]:hadoop集群搭建(hdfs) 1. Hadoop下载 官网下载地址: https://hadoop.apache.org/releases.html,进入官网根据自己需要下载具体的安 ...