首先我们先来认识一下Python的数据类型转换
函数 | 说明 |
---|---|
int(x) |
将x转化为整型 |
float(x) |
将x转化为浮点型 |
complex(real [,imag ]) | 创建⼀一个复数,real为实部,imag为虚部 |
str(x ) |
将对象 x 转换为字符串 |
repr(x ) | 将对象 x 转换为表达式字符串 |
eval(str ) |
⽤用来计算在字符串串中的有效Python表达式,并返回⼀一个对象 |
tuple(s ) |
将序列列 s 转换为⼀一个元组 |
list(s ) |
将序列列 s 转换为⼀一个列表 |
chr(x ) | 将⼀一个整数转换为⼀一个Unicode字符 |
ord(x ) | 将⼀一个字符转换为它的ASCII整数值 |
hex(x ) | 将⼀一个整数转换为⼀一个⼗十六进制字符串 |
oct(x ) | 将⼀一个整数转换为⼀一个⼋八进制字符串 |
bin(x ) | 将⼀一个整数转换为⼀一个⼆二进制字符串 |
以上划重点的是常用的 其他的作为了解即可
接下来我们有个需求 比如 用户输入了一个1 把这个1转化为整型 该怎么解决呢
请看代码
num = input("请输入您喜欢的数字")
print(num)
print(type(num))
print(type(int(num)))
我们就可以看到这里把传进来的字符串1 转化为整型
然后 我们再来测试一下其他几个
# 转换浮点型
num = 1
num1 = float(num)
print(num1, "\t", type(num1))
# 转换字符串
num2 = 10
str1 = str(num2)
print(str1, type(str1))
# 将序列转化为元组
list1 = [1,2,3,4]
print(type(list1))
tuple1 = tuple(list1)
print(tuple1,type(tuple1))
# 将元组转化为序列
tuple2 = (1,2,3,4)
print(type(tuple2))
list2 = list(tuple2)
print(list2,type(list2))
# 将一个字符串 转化为原有类型
str2 = "1"
str3 = "(1,2,3)"
str4 = "[1,2,3,4]"
print(type(eval(str2)),type(eval(str3)),type(eval(str4)))
这就是以上的用法
接下来到了运算符环节
1.算数运算符
运算符 | 描述 | 实例 |
---|---|---|
+ | 加 | 1 + 1 输出结果为 2 |
- | 减 | 1-1 输出结果为 0 |
* | 乘 | 2 * 2 输出结果为 4 |
/ | 除 | 10 / 2 输出结果为 5 |
// | 整除 | 9 // 4 输出结果为2 |
% | 取余 | 9 % 4 输出结果为 1 |
** | 指数 | 2 ** 4 输出结果为 16,即 2 * 2 * 2 * 2 |
() | 小括号 | 小括号⽤用来提⾼高运算优先级,即 (1 + 2) * 3 输出结果为 9 |
注意 python也是双精度浮点数 在运算0.2+0.1的时候也会出现和js相同的问题0.3000000000004的误差
2.赋值运算符
= 将等号左侧的数值赋予给右侧
num = a = 1
#这样num和a都是1
多个变量一起声明呢
num1, float1, str1 = 10, 0.5, 'hello world'
这样声明
3.复合赋值运算符
运算符 | 描述 | 实例 |
---|---|---|
+= | 加法赋值运算符 | c += a 等价于 c = c + a |
-= | 减法赋值运算符 | c -= a 等价于 c = c- a |
*= | 乘法赋值运算符 | c *= a 等价于 c = c * a |
/= | 除法赋值运算符 | c /= a 等价于 c = c / a |
//= | 整除赋值运算符 | c //= a 等价于 c = c // a |
%= | 取余赋值运算符 | c %= a 等价于 c = c % a |
**= | 幂赋值运算符 | c ** = a 等价于 c = c ** a |
a = 100
a += 1
# 输出101 a = a + 1,最终a = 100 + 1
print(a)
b = 2
b *= 3
# 输出6 b = b * 3,最终b = 2 * 3
print(b)
c = 10
c += 1 + 2
# 输出13, 先算运算符右侧1 + 2 = 3, c += 3 , 推导出c = 10 + 3
print(c)
4.比较运算符
运算符 | 描述 | 实例 |
---|---|---|
== | 判断相等。如果两个操作数的结果相等,则条件结果为真(True),否则条件结果为假(False) | 如a=3,b=3,则(a == b) 为 True |
!= | 不等于 。如果两个操作数的结果不不相等,则条件为真(True),否则条件结果为假(False) | 如a=3,b=3,则(a == b) 为 True如a=1,b=3,则(a != b) 为 True |
< | 运算符左侧操作数结果是否⼩小于右侧操作数结果,如果⼩小于,则条件为真,否则为假 | 如a=7,b=3,则(a < b) 为 False |
> | 运算符左侧操作数结果是否⼤大于右侧操作数结果,如果⼤大于,则条件为真,否则为假 | 如a=7,b=3,则(a > b) 为 True |
>= | 运算符左侧操作数结果是否⼤大于等于右侧操作数结果,如果⼤大于,则条件为真,否则为假 | 如a=7,b=3,则(a < b) 为 False如a=3,b=3,则(a >= b) 为 True |
<= | 运算符左侧操作数结果是否⼩小于等于右侧操作数结果,如果⼩小于,则条件为真,否则为假 | 如a=3,b=3,则(a <= b) 为 True |
接下来看代码
a = 7
b = 5
print(a == b) # False
print(a != b) # True
print(a < b) # False
print(a > b) # True
print(a <= b) # False
print(a >= b) # True
5.逻辑运算符
运算符 | 逻辑表达式 | 描述 | 实例 |
---|---|---|---|
and | x and y | 布尔"与":如果 x 为 False,x and y 返回False,否则它返回 y 的值 | True and False, 返回False |
or | x or y | 布尔"或":如果 x 是 True,它返回 True,否则它返回 y 的值。 | False or True, 返回True。 |
not | not x | 布尔"非":如果 x 为 True,返回 False 。如果 x为 False,它返回 True。 | not True 返回 False, not False 返回 True |
接下来看代码
a = 1
b = 2
c = 3
print((a < b) and (b < c)) # True
print((a > b) and (b < c)) # False
print((a > b) or (b < c)) # True
print(not (a > b)) # True
a = 0
b = 1
c = 2
# and运算符,只要有⼀一个值为0,则结果为0,否则结果为最后⼀一个⾮非0数字
print(a and b) # 0
print(b and a) # 0
print(a and c) # 0
print(c and a) # 0
print(b and c) # 2
print(c and b) # 1
# or运算符,只有所有值为0结果才为0,否则结果为第⼀一个⾮非0数字
print(a or b) # 1
print(a or c) # 2
print(b or c) # 1
接下来有一张运算优先级的图
好了今天就更新到这里 下一章 条件循环语句