python 零基础入门教程第 2 章:基本数据类型 (一)

一、什么是数据类型
编程语言通过一些复杂的计算机物理底层机制,创造不同类型的数据,用来表示现实世界中的不同信息,以便于计算机更好的存储和计算。
每种编程语言都会有一些基本的数据类型用来表示现实世界中的常见信息。
Python 中的常见数据类型如下
数值类型

序列类型

散列类型

其他类型

二、数值类型
1. 整数类型(int)
python 中整数类型用 int
表示,与数学中的整数概念一致
age = 18
其中 age 是变量名,=
是赋值运算符,18
是值。
上面的代码表示创建一个整数 18 然后赋值给变量 age。
1.变量
在程序运行过程中会有一些中间值,在稍后的执行中会用到,这时可以将这些中间值赋值给变量,然后在后面的代码中通过调用这些变量名来获取这些值。可以简单的理解为给这些值取一个别名,这个别名就代表这个值。
变量的命名规则:
由大小写字母 A-Za-z,数字 0-9 和下划线
_
组成不能以数字开头
不能是关键字
变量名大小写敏感
# 正确的案例lucky_num = 88lucky_num2 = 888
# 错误的案例1lucky_num = 88
# 上面的age 和 Age是两个不同的变量Age = 19
python 官方占用了一些变量名作为程序的关键字,总共 35 个,这些关键字不能作为自定义变量名使用。
import keywordprint(keyword.kwlist)
['False', 'None', 'True', 'and', 'as', 'assert', 'async', 'await', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
2.赋值运算符
在 python 中 = 是赋值运算符,而不是数学意义上的等于号。python 解释器会先计算 = 右边的表达式,然后将结果复制给 = 左边的变量。
res = 1 # 定义变量res赋值为1res = res + 1 # 先计算res + 1 再赋值给变量resres # res的值为2
运行结果:
2
3.type 函数和 print 函数
python 提供了内建函数 type
用来查看值或者变量的类型。
只需要将变量或者值作为参数传入 type
函数即可。
type(age)
运行结果
int
type(18)
运行结果:
int
print
函数用来在屏幕上输出传入的数据的字符串表现形式,是代码调试最重要的函数。
print(age)print(type(age))# 注意交互式输出和print函数输出的区别
运行结果:
18
<class 'int'>
4.整数的常见表示形式
在 python 中整数最常见的是 10 进制整数,也有二进制,八进制和十六进制。
a = 10 # 十进制print('a的类型为:', type(a), a)
a 的类型为: <class 'int'> 10
b = 0b1110 # 二进制print('b的类型为:', type(b),b)
b 的类型为: <class 'int'> 14
c = 0o57 # 八进制print('c的类型为:', type(c),c)
c 的类型为: <class 'int'> 47
d = 0xa5c # 十六进制print('d的类型为:', type(d), d)
d 的类型为: <class 'int'> 2652
5.整数的取值范围
python 中整数类型的理论取值范围是[-无穷,无穷],实际取值范围受限于运行 python 程序的计算机内存大小。
2. 浮点数类型(float)
python 中浮点数数用 float 表示,与数学中的实数概念一致,也可以理解为有小数。
a = 0.0print('a的类型为:', type(a))
a 的类型为: <class 'float'>
1.浮点数的表现形式
在 python 中浮点数可以表示为 a.b
的格式,也可以表示为小写或大写 E
的科学计算法。例如:
a = 0.0print('a的类型为:', type(a))
a 的类型为: <class 'float'>
# 小数部分为零可以省略不写b = 76.print('b的类型为:', type(b))
b 的类型为: <class 'float'>
c = -3.1415926print('c的类型为:', type(c))
c 的类型为: <class 'float'>
d = 9.5e-2print('d的类型为:', type(d))
d 的类型为: <class 'float'>
思考:
浮点数可以表示所有的整数数值,python 为何要同时提供两种数据类型?
相同的操作整数要比浮点数快5-20倍
2.数学运算符
与数学中的常用运算符一致

注意一个浮点数和一个整数进行运算后的结果一定为浮点数
2+1.0
3.0
9/3 # 除法运算的结果一定为float类型
3.0
9//2 # 地板除,向下取整
4
3.组合赋值运算符
赋值运算符与算术运算符可以组合使用,注意算术运算符要写在前面且中间不能有空格。

体现了程序员的"懒惰",这种懒惰大力提倡,使得代码简洁和高效。
a = 1a += 2 # a = a+2a
3
4. 浮点数的不精确性
整数和浮点数在计算机中的表示不同,python 提供无限制且准确的整数计算,浮点数却是不精确的,例如:
0.2+0.1
0.30000000000000004
根据 sys.float_info.dig 的值,计算机只能提供 15 个数字的准确性。浮点数在超过 15 位数字计算中产生的误差与计算机内部采用二进制运算有关。
import sysprint(sys.float_info.dig)
15
思考:
3.1415926535897924*1.23456789 的计算怎么准确
拓展:高精度浮点运算类型
import decimala = decimal.Decimal('3.141952653')b = decimal.Decimal('1.23456789')print(a * b)
3.87895385729411217
5. 浮点数和整数的相互转化
int
,float
是 python 的内置函数,通过它们可以对浮点数类型和整数类型相互转化
a = 1.9# 转化为整数# 通过调用int函数,提取浮点数的整数部分b = int(a)print(b, type(b))
1 <class 'int'>
c = 2# 转化为浮点数# 通过调用float函数,将整数转化为小数部分为0的浮点数d = float(c)print(d, type(d))
2.0 <class 'float'>
3.复数
科学计算中的复数。
a = 12.3+4jprint('a的类型为:', type(a))# 运行结果:a的类型为: <class 'complex'>print(a.real)print(a.imag)
a 的类型为: <class 'complex'>
12.3
4.0
声明:本文作者为柠檬班心蓝老师,转载请注明出处!