这一节,我来简单讲讲python自带的数据结构。

列表(list)

列表是常用的python数据结构,类似于C语言的数组,用来存储多个元素,与之不同的是,C语言的数组中的元素的类型是相同的,而列表可以是不同类型的元素。

创建一个列表可以用一对方括号[]扩起的用逗号,分隔的值(元素)来表示:

>>> list1 = ['a', 'b', 123, 1.2]

我们可以打印这个列表:

>>> print(list1)
['a', 'b', 123, 1.2]

访问列表中的元素可以用列表名[索引]的方式,就像是操作一个变量一样。例如:

>>> print(list1[0]) # 输出第一个元素
a
>>> print(list1[1]) # 输出第二个元素
b
>>> list1[0] = 123 # 为第一个元素赋值
>>> print(list1[2] + list1[3]) # 用元素运算
124.2
>>>

注意:在计算机中,索引一般是从0开始的,也就是说第一个元素的索引是0,依次类推。“索引” 还有另一种称呼——“偏移量”,一个元素的偏移量就是该元素相对于首元素位置的偏移,如第2个元素相对于首元素的偏移为1,第3个元素的偏移量为2……因为第1个元素相对于第1个元素的偏移量显然0,所以“偏移量”这个称呼更有利于记住首元素是0号元素,所以作者更倾向于这个称呼,读者请随意。

访问列表中的元素要注意索引(偏移量)是否越界,比如上面4个元素的列表,如果访问第5个元素将会报错

>>> print(list1[4])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: list index out of range
>>>

上面英文的大致意思是:列表的索引超出范围,刚刚创建的列表只有4个元素,不存在第5元素,当然会报错了。

我们可以创建一个空列表:

>>>list1 = list() # 或者用 list1 = []

可以添加元素

>>> list1 = list()
>>> list1
[]
>>> list1.append('hello') # 添加元素至列表尾部
>>> list1.append(123)
>>> list1.append(['a', 1]) # 嵌套一个列表
>>> list1
['hello', 123, ['a', 1]]
>>>

还可以删除元素:

>>> list1
['hello', 123, ['a', 1]]
>>> del list1[2]
>>> list1
['hello', 123]
>>> list1.remove('hello')
>>> list1
[123]
>>>

我们可以用下一节要讲到的for循环语句来遍历列表:

list1 = [ 'hello', 123, 456.0 ]
# 循环将列表中的元素赋值给变量e
for e in list1:
print(e)

输出如下:

hello
123
456.0

元组(tuple)

元组的用法和列表类似,列表可以改变,如赋值、添加元素、删除元素等,但是元组不可以改变,所以也就不能进行赋值、添加、删除等操作。

元组的用法如下:

>>> tuple1 = (123, 'a', 'b')
>>> tuple1
(123, 'a', 'b')
>>> tuple1 = 123,456,'hello'
>>> tuple1
(123, 456, 'hello')
>>> print(tuple1[1])
456
>>>

上面的例子中表明圆括号()不是必要的,其实逗号,才是元组所用的语法符号,但是创建一个空元组的时候用一对圆括号()而不是一个逗号,,代码如下:

>>> tuple1 = , # 错误
File "<stdin>", line 1
tuple1 = , # 错误
^
SyntaxError: invalid syntax
>>> tuple1 = () # 正确
>>> tuple1
()
>>> tuple1 = tuple() # 也可以这样创建空元组

之前将多个变量同时赋值时,有一句a, b, c = 1, 2, 'hello',这其实是把一个元组1, 2, 'hello赋值给三个变量a, b, c,像这样把一个元组赋值给多个变量的操作称为 “解包”,列表也是可以进行解包的^_^,元组解包操作代码如下:

>>> tuple1
(123, 456, 'hello')
>>> a, b, c = tuple1
>>> a
123
>>> b
456
>>> c
'hello'
>>>

元组同样可以用for语句来遍历:

tuple1 = ( 'hello', 123, 456.0 )
for e in tuple1:
print(e)

输出:

hello
123
456.0

字典(dict)

列表按索引访问元素,索引只能是整数,而有时候我们需要一种更方便的方式操作元素,如:电话簿按照姓名查找电话号码,字典按照单词查找意思。像这样用不是整数的“索引”来访问元素的数据结构叫做字典,在C语言中也叫“关联数组”,字典的“索引”称为 “键”“关键字”,元素称为 “值”“键值”,字典中的每对键和值称为 “项”

创建一个字典的方法是,用一对花括号{}扩起一系列用逗号分隔的键值对(项),其中键值对的表示方法是键:值,即{ 键1:值1, 键2:值2, 键3:值3},代码如下:

>>> dict1 = {'hello':'你好', 'python':'一门计算机语言'}
>>> dict1
{'hello': '你好', 'python': '一门计算机语言'}
>>> dict2 = dict(hello='你好', python='一门计算机语言') # 也可以这样
>>> dict2
{'hello': '你好', 'python': '一门计算机语言'}
>>>

一些简单的操作:

>>> dict1['hello']
'你好'
>>> dict1['python']
'一门计算机语言'
>>> dict1['abc'] = 123 # 创建一个项
>>> dict1
{'hello': '你好', 'python': '一门计算机语言', 'abc': 123}
>>> del dict1['hello'] # 删除键为'hello'的项
>>> dict1
{'python': '一门计算机语言', 'abc': 123}
>>> dict1 = {} # 空字典, 或者用 dict1 = dict()
>>> dict1
{}
>>>

也可用for语句遍历字典,但是for语句遍历的是字典的键,得到了键自然就可以得到值:

dict1 = {'hello':'你好', 'python':'一门计算机语言'}
for k in dict1:
print(k,' =>', dict1[k])

输出如下:

hello  => 你好
python => 一门计算机语言

本节只是简单了解python中常用的数据结构,不作深入探究,同时引出循环语句,接下来详细介绍编程中十分重要的语法——循环语句……

python教程(二)·数据结构初探的更多相关文章

  1. Python基础二. 数据结构、控制流、运算符、真值测试

    一.概述 数据结构上广义上有两种,单一类型和集合类型 单一类型,表示一种对象 集合类型,表示包含多种对象 Python 中的内建的数据类型有str.list.tuple.dict.set.number ...

  2. 简明python教程五----数据结构

    python中有三种内建的数据结构:列表.元组和字典 list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个序列的项目.在python中,每个项目之间用逗号分隔. 列表中的项目应该包括在方 ...

  3. 简明python教程二-----对象

    物理行:是你在编写程序时所看见的. 逻辑行:是Python看见的单个语句. 默认的,python希望每行都只使用一个语句,这样使得代码更加易读. 如果你想要在一个物理行中使用多于一个逻辑行,用分号“: ...

  4. 写给.NET开发者的Python教程(二):基本类型和变量

    从本文开始,我们就要正式了解Python的语法特性了,这章主要介绍基本类型和变量,开始之前先介绍下Python中的标准输入输出. 标准输入输出 前文举过TwoSum问题的例子,但是没有讲到标准输入输出 ...

  5. 简明python教程五----数据结构(下)

    引用 当你创建一个对象并给它赋一个变量的时候,这个变量仅仅引用那个对象,而不是表示这个对象本身!即,变量名指向你计算机中存储那个对象的内存. print 'Simple Assignment' sho ...

  6. PySide——Python图形化界面入门教程(二)

    PySide——Python图形化界面入门教程(二) ——交互Widget和布局容器 ——Interactive Widgets and Layout Containers 翻译自:http://py ...

  7. python教程(零)·前言

    本教程是作者根据自己学习python的经验写下的,一来是想将经验分享给对python同样感兴趣的小白(大神请忽略),二来是想借此加深本人对python的理解,温故而知新. 学习基础 本教程面向的读者, ...

  8. 《简明python教程》笔记一

    读<简明Python教程>笔记: 本书的官方网站是www.byteofpython.info  安装就不说了,网上很多,这里就记录下我在安装时的问题,首先到python官网下载,选好安装路 ...

  9. (原+转)简明 Python 教程:总结

     简明 Python 教程 说明:本文只是对<简明Python教程>的一个总结.请搜索该书查看真正的教程. 第3章 最初的步骤 1. Python是大小写敏感的. 2. 在#符号右面的内容 ...

  10. 【转】简明 Python 教程

    原文网址:http://woodpecker.org.cn/abyteofpython_cn/chinese/ 简明 Python 教程Swaroop, C. H. 著沈洁元  译www.byteof ...

随机推荐

  1. 捕获Task.WhenALl返回的Task的Exception

    如果有一个任务抛出异常,则Task.WhenAll 会出错,并把这个异常放在返回的Task 中.如果多个任务抛出异常,则这些异常都会放在返回的Task 中.但是,如果这个Task 在被await 调用 ...

  2. node-7.2.1 already installed, it's just not linked

    直接在terminal下运行以卸载node和nvm: sudo rm -rf /usr/local/{bin/{node,npm},lib/node_modules/npm,lib/node,shar ...

  3. RabbitMQ的事件总线

    RabbitMQ的事件总线 在上文中,我们讨论了事件处理器中对象生命周期的问题,在进入新的讨论之前,首先让我们总结一下,我们已经实现了哪些内容.下面的类图描述了我们已经实现的组件及其之间的关系,貌似系 ...

  4. awk的简单使用

    awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...

  5. mongoDB 创建数据库、删除数据库

    创建数据库 use 命令 MongoDB 用 use + 数据库名称 的方式来创建数据库.use 会创建一个新的数据库,如果该数据库存在,则返回这个数据库. 语法格式 use 语句的基本格式如下: u ...

  6. Ajax向Controller发送请求并接受数据需要注意的一个细节

    想用Ajax想向Controller发送请求和接收返回的字符等等.Controller中要使用@ResponseBody注解. <script type="text/javascrip ...

  7. VOC 数据集

    可变形网络 :https://github.com/msracver/Deformable-ConvNets VOC数据集: Test 参数 ('PascalVOC', '2007_test', '. ...

  8. 【[CQOI2014]数三角形】

    lx让做的题,其实很简单,难度评到紫令人吃惊 首先读进来\(n,m\)先\(++\),之后就是一个格点数为\(n*m\)的矩阵了 我们直接求很那做,补集转化一下,我们容斥来做 首先所有的情况自然是\( ...

  9. centos 在安装YouCompleteMe时提示 Fatal : pyconfig.h No such file or directory

    问题:centos 在安装YouCompleteMe时提示 Fatal : pyconfig.h No such file or directory 解决:安装python-devel yum ins ...

  10. Eclipse安装Sonarlint插件

    这里安装的是Sonarlint3.6.插件安装非常简单.插件比Sonar更为简单快捷. 一.首先通过点击Eclipse上方Help菜单会出现一个下拉列表,点击其中的Eclipse MarketPlac ...