目录
python中的标识符和保留字
- 我的保留字
- 有一些单词被我赋予了特定的意义,这些单词在给你的任何对象起名字的时候都不能用
保留字
['False', 'None', 'True', '__peg_parser__', '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']
-
我的规则你必须要知道
- 变量、函数、类、模块和其他对象起的名字就叫标识符
- 规则:
- 字母、数字、下划线_
- 不能以数字开头
- 不能是我的保留字
- 我是严格区分大小写的
变量的定义和使用
- 变量是内存中一个带标签的盒子
代码演示
name='马丽亚'
print(name)
print('标识',id(name))
print('类型',type(name))
print('值',name)
运行结果
- 变量由三部分组成
- 标识:表示对象所存储的内存地址,使用内置函数 id(obj) 来获取
- 类型 : 表示的是对象的数据类型,使用内置函数 type(obj) 来获取
- 值 : 表示对象所存储的具体数据,使用 print(obj) 可以将值进行打印输出
- 当多次赋值之后,变量名会指向新的空间
代码演示
name='马丽亚'
print(name)
name='楚溜冰'
print(name)
运行结果
数据类型
-
整数类型
- 英文为 integer ,简写为 int ,可以表示正数、负数和零
- 整数的不同进制表示方式
- 十进制 默认的进制
- 二进制 以 0b 开头
- 八进制 以 0o 开头
- 十六进制 以 0x 开头
代码演示
#整数类型
#可以表示,正数,负数, 0
n1=90
n2=-76
n3=0
print(n1,type(n1))
print(n2,type(n2))
print(n3,type(n3))
#整数可以表示为二进制,十进制,八进制,十六进制
print('十进制',118)
print('二进制',0b10101111) #二进制以0b开头
print('八进制',0o176) #八进制以0o开头
print('十六进制',0x1EAF)
运行结果
-
浮点类型
- 浮点数整数部分和小数部分组成
- 浮点数存储不精确性
- 使用浮点数进行计算时,可能会出现小数位数不确定的情况
- 解决方案
代码演示
a=3.14159
print(a,type(a))
n1=1.1
n2=2.2
n3=2.1
print(n1+n2)
print(n1+n3)
from decimal import Decimal
print(Decimal('1.1')+Decimal('2.2'))
运行结果
-
布尔类型
- 用来表示真或假的值
- True 表示真, False 表示假
- 布尔值可以转化为整数
- True>1
- False>0
代码演示
f1=True
f2=False
print(f1,type(f1))
print(f2,type(f2))
#布尔值可以转成整数计算
print(f1+1) #2 1+1的结果为2 True表示1
print(f2+1) #1 0+1的结果为1,False表示0
运行结果
-
字符串类型
- 字符串又被称为不可变的字符序列
- 可以使用单引号''双引号"" 三引号''' '''
或""" """来定义 - 单引号和双引号定义的字符串必须在一行
- 三引号定义的字符串可以分布在连续的多行
代码演示
str1='人生苦短,我用Python'
str2="人生苦短,我用Python"
str3="""人生苦短,
我用Python"""
str4='''人生苦短,
我用Python'''
print(str1,type(str1))
print(str2,type(str2))
print(str3,type(str3))
print(str4,type(str4))
运行结果
数据类型转换
- 为什么需要数据类型转换?
- 将不同数据类型的数据拼接在一起
代码演示
name='张三'
age=20
print(type(name),type(age)) #说明name与age的数据类型不相同
#print('我叫'+name+'今年,'+age+'岁') #当将str类型与int类型进行连接时,报错,解决方案,类型转换
print('我叫'+name+'今年,'+str(age)+'岁') #将int类型通过str()函数转成了str类型
print('----------------str()将其它类型转成str类型---')
a=10
b=198.8
c=False
print(type(a),type(b),type(c))
print(str(a),str(b),str(c),type(str(a)),type(str(b)),type(str(c)))
print('----------int()将其它的类型转int类型-----------------')
s1='128'
f1=98.7
s2='76.77'
ff=True
s3='hello'
print(type(s1),type(f1),type(s2),type(ff),type(s3))
print(int(s1),type(int(s1))) #将str转成int类型 ,字符串为 数字串
print(int(f1),type(int(f1))) #float转成int类型,截取整数部分,舍掉小数部分
#print(int(s2),type(int(s2))) #将str转成int类型,报错,因为字符串为小数串
print(int(ff),type(int(ff)))
#print(int(s3),type(int(s3))) #将str转成int类型时,字符串必须为数字串(整数),非数字串是不允许转换
print('------------float()函数,将其它数据类型转成float类型')
s1='128.98'
s2='76'
ff=True
s3='hello'
i=98
print(type(s1),type(s2),type(ff),type(s3),type(i))
print(float(s1),type(float(s1)))
print(float(s2),type(float(s2)))
print(float(ff),type(float(ff)))
#print(float(s3),type(float(s3))) #字符串中的数据如果是非数字串,则不允许转换
print(float(i),type(float(i)))
运行结果
<class 'str'> <class 'int'>
我叫张三今年,20岁
----------------str()将其它类型转成str类型---
<class 'int'> <class 'float'> <class 'bool'>
10 198.8 False <class 'str'> <class 'str'> <class 'str'>
----------int()将其它的类型转int类型-----------------
<class 'str'> <class 'float'> <class 'str'> <class 'bool'> <class 'str'>
128 <class 'int'>
98 <class 'int'>
1 <class 'int'>
------------float()函数,将其它数据类型转成float类型
<class 'str'> <class 'str'> <class 'bool'> <class 'str'> <class 'int'>
128.98 <class 'float'>
76.0 <class 'float'>
1.0 <class 'float'>
98.0 <class 'float'>
进程已结束,退出代码0
-
注释
- 在代码中对代码的功能进行解释说明的标注性文字,可以提高
代码的可读性 - 注释的内容会被 Python 解释器忽略
- 通常包括三种类型的注释
- 单行注释 以” #” 开头,直到换行结束
- 多行注释 并没有单独的多行注释标记,将一对三引号之间的代码称
为多行注释 - 中文编码声明注释在文件开头加上中文声明注释,用以指定源码文件
的编码格式
- 在代码中对代码的功能进行解释说明的标注性文字,可以提高
代码演示
#输入功能 (单行注释)
print('hello')
'''嘿嘿,
我是
多行注释'''
运行结果
中文编码声明
#coding:utf-8
知识点总结