开发|浅谈python数据类型

在回顾Python基础的时候,遇到最大的问题就是内容很多,而我的目的是回顾自己之前学习的内容,进行相应的总结,所以我就不玩基础了,很多在我实际生活中使用的东西,我会在文章中提一下。并且我自己会根据这些内容进行相应的补充与扩展。

文章定位:不是科普文,是自己对于自己学习的总结。

前言

目前所有的文章思想格式都是:知识+情感。
知识:对于所有的知识点的描述。力求不含任何的自我感情色彩。
情感:用我自己的方式,解读知识点。力求通俗易懂,完美透析知识。

正文

正文的主要内容是:Python的所有数据类型,包含None,布尔,数字,字符串,元祖,字典,集合,有序字典,冰冻集合。

基础知识

1.首先,需要知道Python这个语言是怎么自己区分数据类型的,使用的是:type() 方法

s = 'rongming'
print(type(s)) # <class 'str'>

None类型

None表示的就是Python中的None。作为Python中的一种数据类型哈,一般人估计不知道,记一下~~

a = None
print(type(a)) # <class 'NoneType'>

布尔类型

布尔类型:True/False

当Python进行比较远算的时候,就会得到布尔类型的结果。

In [1]: type(None)
Out[1]: NoneType In [2]: a = 10
In [3]: b = 8
In [4]: c = a > b In [5]: c
Out[5]: True In [6]: print(type(c))
<class 'bool'>

数字类型

数字类型: int/float(整型/浮点型)

整型就是整数,浮点型就是小数。

注意:没有long 型

In [7]: num = 666
In [8]: num1 = 1.666 In [9]: type(num)
Out[9]: int In [10]: type(num1)
Out[10]: float

字符串类型

1.字符串类型:str,属于不可变数据类型。

2.字符串是字符的集合,并且需要使用单引号和双引号包含着。

3.字符串的操作函数

字符串的操作函数源码如下:

In [12]: dir(s)
Out[12]:
[ 'capitalize', 'casefold', 'center', 'count', 'encode', 'endswith', 'expandtabs', 'find', 'format', 'format_map', 'index', 'isalnum', 'isalpha', 'isascii', 'isdecimal', 'isdigit', 'isidentifier', 'islower', 'isnumeric', 'isprintable', 'isspace', 'istitle', 'isupper', 'join', 'ljust', 'lower', 'lstrip', 'maketrans', 'partition', 'replace', 'rfind', 'rindex', 'rjust', 'rpartition', 'rsplit', 'rstrip', 'split', 'splitlines', 'startswith', 'strip', 'swapcase', 'title', 'translate', 'upper', 'zfill']

4.常用的字符串操作函数

1)切片操作,基于字符串中的每一个字符进行切片

2)字符串的转义,使用两个 \

3)center() 可以生成标题,左右包含指定符号

4)count() 字符串数据类型中的字符数

5)encode 编码,编码转换使用

6)decode 解码,编码转换使用

7) format() 字符串的格式化,适合在格式化的时候同一变量多处出现

8) isdigit() 判断字符串是不是数字

9)islower/isupper 表示字母是不是小写/大写

10)join 进行字符串的拼接,很常用

11)lstrip 去除字符串左边空格

12)strip 去除字符串两边空格

13)rstrip去除字符串右边空格

14)replace进行字符串的替换

15)split 进行字符串的切分

16)rsplit 进行字符串的切分

17)startswith 判断是不是以什么开头

18)lower 统一为小写

19)upper 统一为大写

元祖类型

1.元祖类型: tuple,属于不可变数据类型, ()

2.常用函数:

index() 返回对应元素的下标

count() 统计元祖的个数

3.元祖的可修改

1)注意:虽然元祖属于不可变数据类型,但是依然可以修改元祖里面的值

2)注意:在底层,不可变数据类型只是当前的表示是不可修改的,但是嵌套可变数据类型就可以修改,基于内部存放的是内存地址原理。

In [26]: tu = (1, 2, 3, [4, 5, 6])

In [27]: tu
Out[27]: (1, 2, 3, [4, 5, 6]) In [28]: tu[3][0] = 'rongming' In [29]: tu
Out[29]: (1, 2, 3, ['rongming', 5, 6])

列表类型

1.列表数据类型: list ,属于可变数据类型。使用[].

2.列表类型常用函数源码:

    In [32]: dir(d)
Out[32]:
[ 'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort']

3.常用的函数

1)append() 添加元素到列表的最后

2)pop() 弹出最后一个元素(为空报错)

3)extend() 将两个列表合并

4)切片[ start: end : step]

5)len 看列表的长度

6)for循环遍历

7)enumerate() 进行列表的遍历

4)列表生成式

In [33]: a = [i for i in range(10)]

In [34]: a
Out[34]: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

字典类型

1.字典类型:** dict,, 属于可变数据类型,使用 {} 表示。**

2.字典的结构: {key: value, key: value, key: value, .....}

注意: key是哈希值,所以字典的查询速度快

补充知识点:hash知识,见hash。

3.字典常见函数

 'clear',
'copy',
'fromkeys',
'get', # 获得字典中键对应的值
'items',
'keys',
'pop',
'popitem',
'setdefault', # 返回已经存在值,没有就修改
'update', # 覆盖现象
'values'

4.字典生成式

In [5]: m = {i:i*3 for i in range(8)}

In [6]: m
Out[6]: {0: 0, 1: 3, 2: 6, 3: 9, 4: 12, 5: 15, 6: 18, 7: 21}

5.深浅拷贝(两层与多层的区别)

1)注意:python底层对于数据的存储是使用的内存地址进行映射。

2)所有的可变数据类型,都是由不可变数据类型拼凑的

3)所有的不可变数据类型,都是对于内部的单位整体是不可变的。

4)可以使用copy工具包进行数据的deepcopy,实现数据的完全分离。如果只是简单的赋值与copy只可以解决一层嵌套关系。

In [8]: d = {'a':[1, 2, 3], 'b': [6, 7, 8]}

In [9]: d
Out[9]: {'a': [1, 2, 3], 'b': [6, 7, 8]} In [10]: f = d In [11]: f['a'][0] = 'rongming' In [12]: d
Out[12]: {'a': ['rongming', 2, 3], 'b': [6, 7, 8]} In [13]: f
Out[13]: {'a': ['rongming', 2, 3], 'b': [6, 7, 8]}

集合类型

1.结合数据类型:** set, 属于可变数据类型,使用{}表示。**

2.集合天然去重,所以集合具有无序的性质与不重复的性质。

3.常用的函数

 'add',
'clear',
'copy',
'difference', # -
'difference_update',
'discard',
'intersection', # &
'intersection_update',
'isdisjoint',
'issubset',
'issuperset',
'pop', # 随机pop出一个元素
'remove',
'symmetric_difference',
'symmetric_difference_update',
'union', # |
'update'

冰冻集合

1.注意:冰冻集合, frozenset属于不可变数据类型。所以不能进行修改

In [21]: f = {1, 2, 3, 4, 5}

In [22]: d = frozenset(f)

In [23]: d
Out[23]: frozenset({1, 2, 3, 4, 5})

2.可以使用的函数

 'copy',
'difference',
'intersection',
'isdisjoint',
'issubset',
'issuperset',
'symmetric_difference',
'union'

有序字典

1.有序字典:OrderedDict,保证了字典中的key的有序,在大量数据的时候,可以使用这个办法进行数据的快速查找(二分法了解一下~~)。

In [25]: from collections import OrderedDict

In [26]: d = OrderedDict({'name':'rongming', 'age':20})

In [27]: d
Out[27]: OrderedDict([('name', 'rongming'), ('age', 20)])

2.常用函数

 'clear',
'copy',
'fromkeys',
'get',
'items',
'keys',
'move_to_end',
'pop',
'popitem',
'setdefault',
'update',
'values'

hash

1)hash散列值具有不可逆与计算速度快的特点。

2)python 实现hash

注意:python中 重启之后hash的值不一样

>>> hash('rongming')
3985893259886982844
>>> hash('rongming')
3985893259886982844

3)hash 的使用

MD5(不要使用同一个密码注册多个账号,每一个数据库存储的密码不一定是密文)

数字签名(公钥,私钥)

区块链

结束语

本文基本上涵盖了所有的Python数据类型,量很大,算是自己对于自己之前学习的一个浓缩。

当现在会看当时自己学习的内容的时候,万分感慨,真的是那句话:’终究还是自己感动了自己啊!‘

最新文章

  1. 安装Appium-windows
  2. 冰冻三尺非一日之寒--web来了
  3. Xamarin的不归路-ios模拟器没有键盘
  4. [Centos] Centos 7笔记
  5. knockout+bootstrap--一些复杂的应用合集
  6. MVP 2015社区大讲堂之:在ASP.NET应用中执行后台任务
  7. P2882 Face The Right Way - USACO07MAR
  8. angular filter
  9. Android的onCreateOptionsMenu()创建菜单Menu详解
  10. Oracle bbed 实用示例-----File Header Reset
  11. 设置window窗口的背景色为护眼色
  12. Oracle执行计划顺序
  13. kafka全部数据清空与某一topic数据清空
  14. css页面滚动触发动画
  15. Web 端异步下载文件
  16. 2017-2018 ACM-ICPC, Asia Daejeon Regional Contest C(记忆化搜索)
  17. MVC4升级到MVC5未能加载文件或程序集System.Web.WebPages.Razor, Version=3.0.0.0
  18. ReportMachine OCX
  19. android-------非常好的图片加载框架和缓存库(Picasso)
  20. android studio打包apk

热门文章

  1. Qt窗口退出与事件循环退出的问题
  2. iOS安全攻防(一):Hack必备的命令与工具
  3. 使用Flask构建一个Web应用
  4. 配置同时使用 Gitlab、Github、Gitee(码云) 共存的开发环境
  5. 详解TCP与UDP
  6. input 控件常用属性
  7. 【转】理解并设计rest/restful风格接口
  8. Linux上发布E卡通项目
  9. 《阿里如何实现秒级百万TPS?搜索离线大数据平台架构解读》--阅读
  10. Visual Studio 2017 编译 gens 世嘉模拟器