开发技术--浅谈python数据类型

时间:2022-07-06 15:03:44

开发|浅谈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数据类型,量很大,算是自己对于自己之前学习的一个浓缩。
当现在会看当时自己学习的内容的时候,万分感慨,真的是那句话:’终究还是自己感动了自己啊!‘