Python基础—变量与数据
Python基础之——变量与数据
变量、运算符与数据类型
1.注释
不管学什么语言,注释都非常的重要,对于Python,有三种注释方法:
(1) # 表示单行注释,作用范围是该行。
(2) “”" “”"和’’’ ‘’'这两者表示区间注释,作用范围是三引号之间。
注意事项
两种三引号注释只适用于开头或代码中的注释,写在最后会成为转义。
2.运算符
运算符包括算术运算符、比较运算符、逻辑运算符、位运算符、三元运算和其他运算符
算数运算符
操作符 | 名称 |
---|---|
+ | 加 |
- | 减 |
* | 乘 |
/ | 除 |
// | 整除(地板除) |
% | 取余 |
** | 幂 |
算数运算符的结果为数字
比较运算符
操作符 | 名称 |
---|---|
> | 大于 |
>= | 大于等于 |
< | 小于 |
<= | 小于等于 |
== | 等于 |
!= | 不等于 |
比较运算符的结果为布尔值
逻辑运算符
操作符 | 名称 |
---|---|
and | 与 |
or | 或 |
not | 非 |
逻辑运算符的结果为布尔值
位运算符
操作符 | 名称 |
---|---|
~ | 按位取反 |
& | 按位与 |
| | 按位或 |
^ | 按位异或 |
<< | 左移 |
>> | 右移 |
可以借助bin()输出二进制字符串,如:print(bin(4^5)); 输出:0b1
也可以输出数字,如:print(4^5); 输出:1。
三元运算符
以下代码块为找出最大值
if a>b: max = a; else: max = b;
但是,对于这个代码块,Python提供了一种更加简洁的写法,如下所示:
max = a if a>b else max = b;
有了这个三元运算符,你将可以使用这一条语句来实现条件判断和赋值操作
其他运算符
操作符 | 名称 |
---|---|
in | 存在 |
not in | 不存在 |
is | 是 |
not is | 不是 |
注意事项
1.is和not is对比的是两个变量的内存地址,而==和!=对比的是两个变量的值。
2.比较的两个变量,指向的都是地址不可变的类型(str等),那么is,not is和==,!=是完全等价的。
3.对比的两个变量,指向的是地址可变的类型(list,dict,tuple等),则两者是有区别的。
运算符的优先级
1.一元运算符优于二元运算符。
2.先算数运算,后位移运算,最后位运算。
3.逻辑运算最后结合。
3.变量和赋值
1.变量在使用之前,需先对其赋值。
2.变量名可以包括字母、数字、下划线、但变量名不能以数字开头。
3.变量名大小敏感,即大写不能相当于小写。
4.数据类型转换
类型 | 名称 |
---|---|
int | 整型 |
float | 浮点型 |
bool | 布尔型 |
借助type()可以查看数据类型
dir内置函数
在 Python 中 对象几乎是无所不在的,我们之前学习的 变量、数据、函数 都是对象,在Python中可以使用一下两种方法来验证:
1.在标识符/数据后输入一个.,然后按下TAB键,Python会提示该对象能够调用的方法列表。
2.使用内置函数dir传入标识符/数据,可以查看对象内的所有属性和方法。
注意
__方法名__格式的方法是 Python 提供的 内置方法 / 属性,以下是一些常用的 内置方法 / 属性
方法名 | 作用 |
---|---|
__new__ | 创建对象时,会被自动调用 |
__init__ | 对象被初始化时,会自动调用 |
__del__ | 对象被从内存中销毁前,会被自动调用 |
__str__ | 返回对象的描述信息,print函数输出使用 |
bit_length():找到一个整数的二进制表示,再输出其长度。
浮点型
有时候我们想保留浮点型的小数点后 n 位。可以用 decimal 包里的 Decimal 对象和 getcontext() 方法来实现
import decimal from decimal import Decimal
Decimal对象默认的精度是28位
可以通过getcontext().prec来调整精度
例如:
decimal.getcontext().prec = 5 c = Decimal(1) / Decimal(3) print(c) # 0.33333
除了直接给变量赋值 True 和 False,还可以用 bool(X) 来创建变量,其中 X 可以是
基本类型:整型、浮点型、布尔型
容器类型:字符串、元组、列表、字典和集合
bool 作用在基本类型变量:X 只要不是整型 0、浮点型 0.0,bool(X) 就是 True,其余就是 False。
【例子】
print(type(0), bool(0), bool(1)) #<class 'int'> False True print(type(10.31), bool(0.00), bool(10.31)) #<class 'float'> False True print(type(True), bool(False), bool(True)) #<class 'bool'> False True
bool 作用在容器类型变量:X 只要不是空的变量,bool(X) 就是 True,其余就是 False。
print(type(''), bool(''), bool('python')) # <class 'str'> False True print(type(()), bool(()), bool((10,))) # <class 'tuple'> False True print(type([]), bool([]), bool([1, 2])) # <class 'list'> False True print(type({}), bool({}), bool({'a': 1, 'b': 2})) # <class 'dict'> False True print(type(set()), bool(set()), bool({1, 2})) # <class 'set'> False True
1.对于数值类型0,0.0都可以认为是空的。
2.对于容器变量,里面没有元素就是空的。
判断bool(X)的值是True还是False,主要是看里面的X,X是空就是False,不是空就是True。
注意
上面提到过的type()可以查看数据类型,它不会认为子类是一种父类类型,不考虑继承关系,而isinstance()会认为子类是一种父类类型,考虑继承关系。
类型转换
转换为整型 int(x, base=10)
转换为字符串 str(object=’’)
转换为浮点型 float(x)
5.print()函数
print(*object,sep='',end='\n',file=sys.stdout,flush=False)
·将对象以字符串表示的方式格式化输出到流文件对象file里。其中所有非关键字参数都按str()方式转换为字符串输出;
·关键字sep是实现分隔符,比如多个参数输出时想要输出中间的分隔字符;
·关键字参数end是输出结束时的字符,默认是换行符\n;
·关键字参数file是定义流输出的文件,可以是标准的系统输出sys.stdout,也可以重新定义为别的文件;
·关键字参数flush是立即把内容输出到流文件,不做缓存
【例子】当print()函数中没有任何参数时,每次输出后都会默认换行
shoplist = ['apple','mango','carrot','banana'] print("This is printed without 'end'and 'sep'.") for item in shoplist: print(item)
【例子】每次输出结束都用end设置的参数&结尾,并不默认换行
shoplist = ['apple','mango','carrot','banana'] print("This is printed with 'end='&''.") for item in shoplist: print(item,end='&') print("Hello World!")
【例子】item的值与’another string’两个值之间用sep设置的参数&分割。由于end参数没有设置,因此默认是输出解释后换行,end参数的默认值是\n。
shoplist = ['apple','mango','carrot','banana'] print("This is printed with 'sep='&''.") for item in shoplist: print(item,'another string',sep='&')
本文地址:https://blog.csdn.net/qq_43496522/article/details/108248767