Python入门_浅谈数据结构的4种基本类型


Posted in Python onMay 16, 2017

数据结构:通俗点说,就是储存大量数据的容器。这里主要介绍Python的4种基本数据结构:列表、字典、元组、集合。

格式如下:

列表:list = [val1,val2,val3,val4],用中括号;
字典:dict = {key1:val1,key2:val2},大括号,且每个元素是带有冒号的key与val的对应关系组;
元组:tuple = (val1,val2,val3,val4),小括号;
集合:set = {val1,val2,val3,val4},大括号。

1. 列表:

list = [val1,val2,val3,val4]

列表最显著的特征是:

列表中每个元素都是可变的;
列表中的元素都是有序的,即每个元素都有一个位置;
列表可以容纳Python中的任何对象。
接下来看下列表的增删改查。

增:

1 list = [1,'dwd',3.6]
2 list.insert(0,'Python')
3 print(list)

用insert方法可以实现在列表中增加元素。insert方法需要写明增加在哪个位置和增加的内容,新增元素的实际位置是在指定位置元素之前的位置;如果指定的位置不存在,默认会增加在列表末尾。

1 list = [1,'dwd',3.6]
2 list[0:0] = [9]
3 # 【0:0】是指在list中的第1个位置插入新元素
4 list[3:3] = ['a']
5 # 【3:3】是指在list中的第4个位置插入新元素
6 print(list)

上面说到的这两种方法都是添加单个元素,除了添加单个元素外,还可以添加多个元素,用extend方法来实现。

1 list_a = [1,'dwd',3.6]
2 list_b = ['Python',56,'game']
3 list_a.extend(list_b)
4 # extend方法用于在列表末尾一次性追加另一个列表中的多个值
5 print(list_a)

 删:

 

1 list = [1,'dwd',3.6]
2 list.remove('dwd')
3 print(list)

 删除列表中的元素除了用上面的remove方法来实现外,也可以用del关键字来声明:

1 list = [1,'dwd',3.6]
2 del list[0:2]
3 # 【0:2】是删除第1和第2个位置的元素
4 print(list)

改:

1 list = [1,'dwd',3.6]
2 list[2] = 7
3 list[0] = 'start'
4 print(list)

如果想要替换掉列表中的某个元素,可以直接给列表某位置的元素重新赋值,list[2]指list列表中的第3个元素。

查:

列表的索引与之前文章《Python入门_浅谈字符串的分片与索引、字符串的方法》中提到的字符串的索引类似,同样是分正反两种索引方式,可以从前往后,也可以从后往前索引。比如:

list = [1,'dwd',3.6]
print(list[1])
# 打印第2个位置的元素
print(list[-1])
# 打印倒数第一个位置的元素
print(list[:2])
# 打印第1和第2个元素
print(list[1:])
# 打印第2到最后一个的元素

但如果想查看某个元素的位置,就不适合用这种方式,程序会报错。因为列表只接受用位置进行索引,不可以通过元素来查找位置。

2. 字典:

dict = {key1:val1,key2:val2}

编程世界中的很多概念都源自于生活,字典也是。这种数据结构如我们使用的字典一样,通过“名称—内容”来构建,在Python中每个元素是带有冒号的key与val的对应关系组,习惯称之为键值对。

字典的特征如下:

字典中的元素必须是键值对的形式;

键(key)不可以重复,而值(val)可以重复;

键不可变,无法修改;值可修改,可以是任何对象。

即使字典中有重复的键,打印出来时也只会出现一次。比如:

1 dict = {'A':'art','B':'big','C':'cute','C':'cute'}
2 print(dict)

接下来看下字典的增删改查。

增:

字典中没有像列表那样有一个现成的insert方法可以使用,但可以通过下面这种方式插入元素,元素默认会插入在最后一个位置。

1 dict = {'A':'art','B':'big','C':'cute'}
2 dict['D'] = 'dictionary'
3 print(dict)

上面讲到在列表中增加多个元素时可以使用extend方法来实现,在字典中也有对应的update方法来实现添加多个元素。

1 dict = {'A':'art','B':'big','C':'cute'}
2 dict.update({'D':'dictionary','E':'exam'})
3 print(dict)

删:

在字典中删除某元素,也可以使用del关键字。

1 dict = {'A':'art','B':'big','C':'cute'}
2 del dict['B']
3 print(dict)

需要注意的是,虽然字典是用大括号的,但在删除时依然使用的是中括号。

改:

如果要修改字典里的元素,直接重新给键赋值即可。

1 dict = {'A':'art','B':'big','C':'cute'}
2 dict['B'] = 'beyond'
3 print(dict)

查:

在字典中进行索引时,和删除一样,用的是中括号,中括号中存放字典的键,也就是说对字典元素进行索引时是通过键来索引的。

1 dict = {'A':'art','B':'big','C':'cute'}
2 dict['B']
3 print(dict['B'])

之前在文章《Python入门_浅谈字符串的分片与索引、字符串的方法》中有提到过字符串的分片,在字典里,字符串是不可以进行分片的。

3. 元组

tuple = (val1,val2,val3,val4)

Python中的元组与列表类似,不同之处在于元组不可以修改,类似于稳固版的列表,因此在列表中可以使用的增删改的方法在元组中是不可以使用的,但是可以对元组中的元素进行索引,和列表类似。

1 tup = (1,2,'s',7)
2 print(tup[0])
3 print(tup[-1])
4 print(tup[1:])
5 print(tup[:-2])

4. 集合

set = {val1,val2,val3,val4}

集合的概念有点接近于数学上的集合。每个集合中的元素是无序的、不重复的任何对象,我们可以通过集合去判断数据的从属关系,有时还可以通过集合把数据结构中重复的元素减掉。

集合不可以被切片也不能被索引,除了做集合运算之外,集合元素可以被添加和删除。

set = {7,1,8,3,4,5,3}
set.add(0)
# 新增元素0
set.discard(7)
# 删除掉元素7
print(set)
# 打印出的集合会从小到达排列,并去重

等后面如果用到集合时,再详细展开集合的运算。

后续会介绍下数据结构的一些小技巧。

操作环境:Python版本,3.6;PyCharm版本,2016.2;电脑:Mac

以上这篇Python入门_浅谈数据结构的4种基本类型就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python与php实现分割文件代码
Mar 06 Python
python字符串过滤性能比较5种方法
Jun 22 Python
Python中用post、get方式提交数据的方法示例
Sep 22 Python
基于Django的python验证码(实例讲解)
Oct 23 Python
Python爬虫_城市公交、地铁站点和线路数据采集实例
Jan 10 Python
pygame游戏之旅 添加游戏介绍
Nov 20 Python
详解用Python为直方图绘制拟合曲线的两种方法
Aug 21 Python
Python.append()与Python.expand()用法详解
Dec 18 Python
python 截取XML中bndbox的坐标中的图像,另存为jpg的实例
Mar 10 Python
Python容器类型公共方法总结
Aug 19 Python
Python GUI之tkinter窗口视窗教程大集合(推荐)
Oct 20 Python
python实现简单的聊天小程序
Jul 07 Python
Python入门_浅谈字符串的分片与索引、字符串的方法
May 16 #Python
python将ansible配置转为json格式实例代码
May 15 #Python
用Python设计一个经典小游戏
May 15 #Python
Python 对象中的数据类型
May 13 #Python
Python中matplotlib中文乱码解决办法
May 12 #Python
使用Python对Csv文件操作实例代码
May 12 #Python
python 读取excel文件生成sql文件实例详解
May 12 #Python
You might like
用session做客户验证时的注意事项
2006/10/09 PHP
PHP6 mysql连接方式说明
2009/02/09 PHP
PHP fgetcsv 定义和用法(附windows与linux下兼容问题)
2012/05/29 PHP
php数组查找函数in_array()、array_search()、array_key_exists()使用实例
2014/04/29 PHP
PHP遍历目录函数opendir()、readdir()、closedir()、rewinddir()总结
2014/11/18 PHP
php实现图片上传、剪切功能
2016/05/07 PHP
PHP面向对象自动加载机制原理与用法分析
2016/10/14 PHP
Laravel框架搜索分页功能示例
2019/02/01 PHP
use jscript with List Proxy Server Information
2007/06/11 Javascript
jquery 子窗口操作父窗口的代码
2009/09/21 Javascript
jquery animate图片模向滑动示例代码
2011/01/26 Javascript
node.js中的fs.chown方法使用说明
2014/12/16 Javascript
学习javascript面向对象 掌握创建对象的9种方式
2016/01/04 Javascript
JavaScript结合Bootstrap仿微信后台多图文界面管理
2016/07/22 Javascript
Javascript 闭包详解及实例代码
2016/11/30 Javascript
vue移动端弹框组件的实例
2018/09/25 Javascript
我要点爆”微信小程序云开发之项目建立与我的页面功能实现
2019/05/26 Javascript
详解vue-cli3多页应用改造
2019/06/04 Javascript
浅谈JS中几种轻松处理'this'指向方式
2019/09/16 Javascript
微信内置开发 iOS修改键盘换行为搜索的解决方案
2019/11/06 Javascript
Python编程实现输入某年某月某日计算出这一天是该年第几天的方法
2017/04/18 Python
python调用摄像头显示图像的实例
2018/08/03 Python
python爬虫之爬取百度音乐的实现方法
2019/08/24 Python
Python面向对象原理与基础语法详解
2020/01/02 Python
Python自动化测试基础必备知识点总结
2021/02/07 Python
从零实现一个自定义html5播放器的示例代码
2017/08/01 HTML / CSS
荷兰电脑专场:Paradigit
2018/05/05 全球购物
斯图尔特·韦茨曼鞋加拿大官网:Stuart Weitzman加拿大
2019/10/13 全球购物
美国在线医疗分销商:MedEx Supply
2020/02/04 全球购物
水利公司纪检监察自我鉴定
2014/02/25 职场文书
工作求职信
2014/07/04 职场文书
死亡证明书样本说明
2014/10/18 职场文书
在Java中Collection的一些常用方法总结
2021/06/13 Java/Android
一次MySQL启动导致的事故实战记录
2021/09/15 MySQL
SSM项目使用拦截器实现登录验证功能
2022/01/22 Java/Android
Golang 链表的学习和使用
2022/04/19 Golang