类型
python中的变量不需要声明,变量在使用前必须赋值,变量赋值以后才会被创建。
在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型。
变量赋值
变量名 = 值
a = 100 # 整型变量
b = 10.0 # 浮点型变量
c = 'string'
print(a, type(a))
print(b, type(b))
print(c, type(c))
100 <class 'int'>
10.0 <class 'float'>
string <class 'str'>
多变量赋值,多个变量赋予相同的值,多个变量赋予不同的值·
a = b = c = 2
d, e, f = 1, 2.0, 'string'
print(a, type(a))
print(b, type(b))
print(c, type(c))
print(d, type(d))
print(e, type(e))
print(f, type(f))
2 <class 'int'>
2 <class 'int'>
2 <class 'int'>
1 <class 'int'>
2.0 <class 'float'>
string <class 'str'>
标准数据类型
python3有6个标准数据类型:不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。
Number数字
Python3 支持 int、float、bool、complex(复数)。
在Python 3里,只有一种整数类型 int,表示为长整型,没有 python2 中的 Long。
像大多数语言一样,数值类型的赋值和计算都是很直观的。
内置的 type() 函数可以用来查询变量所指的对象类型。
a, b, c, d, e = 3, 2.3, True, 1 + 1j, complex(2, 4)
print(type(a), type(b), type(c), type(d), type(e))
<class 'int'> <class 'float'> <class 'bool'> <class 'complex'> <class 'complex'>
# 通过isinstance判断
a = 100
isinstance(a, int)
True
数值运算(+、-、 *、 /、 //、 %、 ** )
/ 一定返回浮点数
在混合计算时,Python会把整型转换成为浮点数。
1 + 2
3
2 - 1.0
1.0
2 * 3
6
2 * 3.0
6.0
4 / 2 # 除法,得到一个浮点数,(无论变量类型是什么样, 都会得到浮点型)
2.0
9 // 4.0 # (向下取整)除法,得到一个整数(整型 // 整型,结果为整型, 整型和浮点型相除,结果为浮点型)
2.0
13 % 2 # 取余, 即取模 (整型与整型,结果为整型, 整型与浮点型, 结果为浮点型)
1
2 ** 3.0 # 乘方运算(整型与整型,结果为整型, 整型与浮点型, 结果为浮点型)
8.0
String字符串,python中的字符串不能被改变,不可以通过索引位置赋值
a = 'string'
print(a[2])
a[2] = 's'
r
--------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-33-45899232cc41> in <module>
1 a = 'string'
2 print(a[2])
----> 3 a[2] = 's'
TypeError: 'str' object does not support item assignment
List(列表)
List(列表) 是 Python 中使用最频繁的数据类型。
列表可以完成大多数集合类的数据结构实现。列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表(所谓嵌套)。
列表是写在方括号 [] 之间、用逗号分隔开的元素列表。
和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。
列表截取格式:
变量[头下标:尾下标:步长],步长默认为1, 同样的,索引值从左往右以0开始,从右往左以-1开始
list_a = [13, 23, 'string', 4.5, 'python']
list_b = [48, 239.8, 'jupyter']
print(type(list_a))
print(list_a)
print(list_a[2])
print(list_a[0:4])
print(list_a[0:-1:2])
print(list_b * 2)
print(list_a + list_b)
<class 'list'>
[13, 23, 'string', 4.5, 'python']
string
[13, 23, 'string', 4.5]
[13, 'string']
[48, 239.8, 'jupyter', 48, 239.8, 'jupyter']
[13, 23, 'string', 4.5, 'python', 48, 239.8, 'jupyter']
列表中的元素可以被改变
a = [1, 3, 4, 5, 'string']
print(a[0])
a[0] = 10
print(a[0])
a[2:4]=[40, 50]
print(a)
b =a[0:3]
print(b)
a[2:4]=[] # 将对应的元素值设置为[]
print(a)
list_a = []
list_b = [2]
list_c = [2,]
print(list_a, type(list_a))
print(list_b, type(list_b))
print(list_c, type(list_c))
[] <class 'list'>
[2] <class 'list'>
[2] <class 'list'>
Tuple(元组)
元组写在小括号()里,元素之间使用逗号隔开
元组中的元素类型也可以不相同
tuple_a = (13, 23, 'string', 4.5, 'python')
tuple_b = (48, 239.8, 'jupyter')
print(type(tuple_a))
print(tuple_a)
print(tuple_a[2])
print(tuple_a[0:4])
print(tuple_a[0:-1:2])
print(tuple_b * 2)
print(tuple_a + tuple_b)
<class 'tuple'>
(13, 23, 'string', 4.5, 'python')
string
(13, 23, 'string', 4.5)
(13, 'string')
(48, 239.8, 'jupyter', 48, 239.8, 'jupyter')
(13, 23, 'string', 4.5, 'python', 48, 239.8, 'jupyter')
tuple_a = (1, 2, 4, 5, 6)
print(tuple_a[1])
tuple_a[1] = 20 # 元组元素不可修改
2
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-45-0bbc56e56349> in <module>
1 tuple = (1, 2, 4, 5, 6)
2 print(tuple[1])
----> 3 tuple[1] = 20
TypeError: 'tuple' object does not support item assignment
虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
list_a = [1, 2, 4]
tuple_a = (5, list_a, 6)
print(tuple_a)
list_a[1] = 20
print(tuple_a)
(5, [1, 2, 4], 6)
(5, [1, 20, 4], 6)
构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则
tup1 = () # 空元组
tup2 = (2,) # 一个元素,需要在元素后添加逗号, 这一点和列表是不相同的
tup3 =(2) # 不加逗号,tup3就是一个Number
print(tup1, type(tup1))
print(tup2, type(tup2))
print(tup3, type(tup3))
() <class 'tuple'>
(2,) <class 'tuple'>
2 <class 'int'>
string、list 和 tuple 都属于 sequence(序列)。
注意:
1、与字符串一样,元组的元素不能修改。
2、元组也可以被索引和切片,方法一样。
3、注意构造包含 0 或 1 个元素的元组的特殊语法规则。
4、元组也可以使用+操作符进行拼接。
Set(集合)
集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。
基本功能是进行成员关系测试和删除重复元素。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
- parame = {value01, value02, value03,…}
- set(value)
name = {'zhang san', 'li si', 'wang wu', 'zhangsan', 'zhang san'}
print(name) # 重复的元素被自动去掉
# 成员测试
if 'zhang san' in name:
print(True)
else:
print(False)
{'li si', 'zhangsan', 'wang wu', 'zhang san'}
True
set可以进行集合运算
set_a = set('abcdefgh')
set_b = set('asasebtg')
print(set_a)
print(set_b)
print(set_a - set_b) # set_a 和set_b的差集
print(set_a | set_b) # set_a 和set_b的并集
print(set_a & set_b) # set_a 和set_b的交集
print(set_a ^ set_b) # set_a 和set_b中不同时存在的元素
{'c', 'f', 'a', 'e', 'd', 'b', 'g', 'h'}
{'a', 's', 'e', 't', 'b', 'g'}
{'c', 'h', 'f', 'd'}
{'c', 'f', 'a', 's', 'e', 't', 'd', 'b', 'g', 'h'}
{'e', 'b', 'g', 'a'}
{'c', 'f', 's', 't', 'd', 'h'}
Dictionary(字典)
字典(dictionary)是Python中另一个非常有用的内置数据类型。
列表是有序的对象集合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。
字典是一种映射类型,字典用 { } 标识,它是一个无序的 键(key) : 值(value) 的集合。
键(key)必须使用不可变类型。
在同一个字典中,键(key)必须是唯一的。
dict_a = {}
dict_a['one'] = '字典'
dict_a[1] = 'dictionary'
print(dict_a)
print(dict_a['one'])
print(dict_a[1])
dict_b = {'name':'zhang san', 'age':'18', 'age':18, 'hight':'一米七'}
print(type(dict_b), dict_b)
print(dict_b.keys())
print(dict_b.values())
{'one': '字典', 1: 'dictionary'}
字典
dictionary
<class 'dict'> {'name': 'zhang san', 'age': 18, 'hight': '一米七'}
dict_keys(['name', 'age', 'hight'])
dict_values(['zhang san', 18, '一米七'])
# 字典的其他构建方法, 构造函数dict()
#dict([('zhang san', 1),('li si', 2), ('wang wu', 3)])
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-74-a31b0dc25f23> in <module>
1 # 字典的其他构建方法, 构造函数dict()
----> 2 dict([('zhang san', 1),('li si', 2), ('wang wu', 3)])
TypeError: 'dict' object is not callable
a = dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
print(a)
--------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-79-444865f1b14d> in <module>
----> 1 a = dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
2 print(a)
TypeError: 'dict' object is not callable
{x: x**2 for x in (1, 2, 3, 4)}
{1: 1, 2: 4, 3: 9, 4: 16}
dict(zhangsan=1, lisi=2, wangwu=3)
---------------------------------------------------------------------------
TypeError Traceback (most recent call last)
<ipython-input-81-7bbc6a452c80> in <module>
----> 1 dict(zhangsan=1, lisi=2, wangwu=3)
TypeError: 'dict' object is not callable
dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
Out[2]: {'Runoob': 1, 'Google': 2, 'Taobao': 3}
dict(zhangsan=1, lisi=2, wangwu=3)
Out[3]: {'zhangsan': 1, 'lisi': 2, 'wangwu': 3}
1、字典是一种映射类型,它的元素是键值对。
2、字典的关键字必须为不可变类型,且不能重复。
3、创建空字典使用 { }。
Python数据类型转换
有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。
以下几个内置的函数可以执行数据类型之间的转换。这些函数返回一个新的对象,表示转换的值。
函数 描述
int(x [,base]) 将x转换为一个整数
float(x) 将x转换到一个浮点数
complex(real [,imag]) 创建一个复数
str(x) 将对象 x 转换为字符串
repr(x) 将对象 x 转换为表达式字符串
eval(str) 用来计算在字符串中的有效Python表达式,并返回一个对象
tuple(s) 将序列 s 转换为一个元组
list(s) 将序列 s 转换为一个列表
set(s) 转换为可变集合
dict(d) 创建一个字典。d 必须是一个 (key, value)元组序列。
frozenset(s) 转换为不可变集合
chr(x) 将一个整数转换为一个字符
ord(x) 将一个字符转换为它的整数值
hex(x) 将一个整数转换为一个十六进制字符串
oct(x) 将一个整数转换为一个八进制字符串