一、运算符
python支持:数学运算符、比较运算符、逻辑运算符、赋值运算符、(位运算符)
1. 数字运算符
符号 | 意义 |
---|---|
+ | 加法 |
- | 减法 |
* | 乘法 |
/ | 除法 |
% | 取余 |
// | 整除 |
** | 幂运算 |
注意
a.其中+、-、*、/和数学中的加减乘除一模一样
b.//(整除), 数字1 // 数字2 --> 让数字1除以数字
2,结果只取整数部分
c. %(取余) , 求余数
d. **(幂运算), x ** y --> 求x的y次方
例子:
print(12.6 + 5)
print(100 - 110)
print(2 * 3)
print(5 / 2)
print(5 // 2) # 2
print(5 % 2) # 求5除以2的余数
print(10 ** 4)
print(16 ** 0.5) # x ** 0.5 == x ** (1/2) == x开平方
2. 比较运算符
符号 | 意义 |
---|---|
> | 大于 |
< | 小于 |
== | 等于 |
!= | 不等于 |
>= | 大于等于 |
<= | 小于等于 |
注意:
所有的比较运算符的结果都是布尔值
例子:
print(10 > 20) # False
print(10 < 20) # True
print(10 == 20) # False
print(10 == 10) # True
print(10 != 20) # True
print(10 != 10) # False
print(10 >= 20) # False
print(20 >= 20) # True
补充
一个变量有三要素,分别是:类型(变量中存储的数据的类型)、值(给变量赋值的数据)、地址(变量真正存储的内容,数据的地址)
类型 - type(变量)
值 - 直接使用变量,就是使用值
地址 - id(变量)
== 和 is的区别 (应付面试!!)
==:判断的是值是否相等
is: 判断的是地址是否相等
如下
list1 = [1, 2]
list2 = [1, 2]
list3 = list1 # 用一个变量给另一个变量赋值的时候,是将变量中存储的数据的地址赋给另外一个变量
print(list1, list2)
print(id(list1), id(list2))
print(list1 == list2, list1 is list2) # True False
print(list1 == list3, list1 is list3) # True True
3. 逻辑运算
符号 | 意义 |
---|---|
and | 逻辑与 |
or | 逻辑或 |
not | 逻辑非 |
逻辑运算符的运算对象和运算结果都是布尔值
a. 值1 and 值2 --> 如果两个都为True结果就是True, 否则结果是False; 相当于生活逻辑中的'并且
True and True -> True
False and True -> False
True and False -> False
False and False -> False
短路操作:如果第一个条件是False, 就不会再去判断第二个条件,直接让整个与运算的结果是False
b. 值1 or 值2 --> 如果两个都为False结果才是False, 否则结果是True; 相当于生活逻辑中的'或者'
True or True -> True
False or True -> True
True or False -> True
False or False -> False
短路操作:如果第一个条件是True, 就不会再去判断第二个条件,直接让整个或运算的结果是True
c. not 值1 --> 对值1进行否定/取反 (不是、否定)
not True -> False
not False -> True
4.赋值运算符
符号 | 意义 |
---|---|
= | 将结果赋给变量 |
+= | 变量 = 变量 + 数字 |
-= | 变量 = 变量 - 数字 |
*= | 变量 = 变量 * 数字 |
/= | 变量 = 变量 / 数字 |
%= | 变量 = 变量 % 数字 |
//= | 变量 = 变量 // 数字 |
**= | 变量 = 变量 ** 数字 |
复合赋值运算符要求赋值符号的左边除了是变量以外,还要求这个变量已经被赋过值
5.运算符的优先级
数学运算符 > 比较运算符 > 逻辑运算符 > 赋值运算符
数学运算符中: ** > *,/,%,// > +,-
优先级高的先算,优先级低的后算。如果有(),先算()里面
二、数字类型
1. 数字类型:int, float, complex, bool
- 整型(int): 包含所有的整数, 支持十进制、二进制、八进制和十六进制
- 浮点型(float): 包含所有的小数, 支持科学计数法
- 布尔(bool): 值只有True == 1和False == 0
4.复数(complex): 实部+虚部j, 注意:j前面必须有数字,不能省略
num0 = 123
num1 = 12.5
num2 = True + 10
print(num2, True == 1, False == 0)
十进制、二进制、八进制和十六进制
num1 = 0b110101 # 二进制:0b+二进制数
num2 = 0o127 # 八进制: 0o+八进制数
num3 = 0x89af # 十六进制: 0x+十六进制数
print(num0, num1, num2, num3) # 打印的是这个数的十进制
print('十进制:', 123)
print('二进制:', bin(123))
print('八进制:', oct(123))
print('十六进制', hex(123))
三、字符串
1.通过单引号或者双q引号括起来的字符集(文本)就是字符串
str1 = 'abc'
str2 = "abc123"
2.str是python自己提供的一种容器型数据类型, 一个字符串中可以存储多个字符
什么是字符:python中只有字符的概念没有字符类型;
如果在python中要表示一个字符,用一个长度是1的字符串来表示
字符串不可变但是有序;不可变指的是字符的值和字符串的长度不可变,有序指的是每个字符在字符串中的位置是确定的
字符串'abc'和字符串'bac'是不一样的
3.字符串中的字符
a.普通字符:包括一般的字母、数字、符号、其他文字, 例如:'a', 'G', '1', '0', '+', '^','?', '好'
b.转义字符:通过在一些特定的字符前加,来表示特殊的功能或者意义, 这样的字符就是转义字符。
\n - 换行
\t - 表示一个tab键
\' - 表示一个单引号
\" - 表示一个双引号
\\ - 表示一个反斜杠
data = 100
data = '100'
str3 = 'agh231好'
str4 = 'abc\n123'
str5 = '\thello\'A'
str6 = "he\"llo'A"
str7 = '\\ahello\\npython'
注意:1.没有阻止转义的时候,一个转义字符的长度是1
2.可以在字符串的最前面加r/R,来阻止转义。(阻止字符串中所有的转义字符转义)
c.编码字符:在字符串中以'\u1234', 这儿的1234表示四位十六进制编码值
4.字符编码
计算机在存储数据的时候只能数字数据,而且存是数字的二进制的补码
10 -> 转换成二进制 -> 求补码(存)
字符的编码就是为了将字符存储到计算中,给每个字符对应的一个固定的数字。这个数字就是这个字符的编码
目前计算机采用的编码方式有两种,分别是ASCII码表和Unicode码表。python中采用的是Unicode编码。
ASCII码是采用一个字节对字符进行编码(总共有128个字符)
Unicode码包含ASCII码,采用两个字节对字符进行编码,包含了世界上所有的语言和符号,又称万国码
小写字母的编码范围(a-z): 97 - 122
大写字母的编码范围(A-Z): 65 - 90
中文编码范围: 0x4e00 ~ 0x9fa5
字符编码相关的函数:
a.chr(编码值) - 获取编码对应的字符
b.ord(字符) - 获取字符的编码(以十进制的形式返回)
print(chr(0x4e90))
print(ord('余'), ord('婷'))
print(hex(ord('余')), hex(ord('婷')))
for x in range(0x1800, 0x18AF+1):
print(chr(x), end=',')
网友评论