首先思考一个问题:python为什么要有类型?开辟空间存储内容

程序 = 数据结构 +算法
数据结构:你处理和存储数据
(重点)算法:解决问题的步骤:分析问题,设计算法,编写程序,调试,完成

 

数据主要分为

  • int(整数型) ;数字的整数
  • float(浮点型); 数字带小数
  • str(字符串); 用 ‘’ 或者 “” 引用的任意文本
  • bool(布尔型);只有 True 和 False

 

基本数据结构

  • list(列表)    #[]
  • tuple(元祖) #()
  • dict(字典)    #{}
  • set(集合)    #set()

 

数值、字符串、元祖是不可变类型;

列表、字典、集合是可变类型

注:严格来讲,序列(列表元组字典集合)是数据结构,而数值字符串布尔值空值是数据类型

 

 

Number(数字)

  • Python3 支持 int、float、bool、complex(复数)
>>> type(3)
<class 'int'>
>>> type(2.2)
<class 'float'>
>>> type(True)
<class 'bool'>
>>> type(1+2j)
<class 'complex'>
>>> 1e10    #科学计数
10000000000.0
>>>

#不同类型的数据之间是不能互相操作的,示例:
>>> a = 1
>>> b = "gloryroad"
>>> a+b
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for +: 'int' and 'str'


#类型转换
int(x) 将x转换为一个整数。
float(x) 将x转换到一个浮点数。
complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。
complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。
如果一定要操作就涉及到数据类型时间的转换,数据类型的转换,你只需要将数据类型作为函数名即可,示例:

 >>> age='18'
 >>> type(age)
 <class 'str'>
 >>> int(age)+10
 28
 >>> str(100)
 '100'

 

 bool布尔型 True和False

总结:

  • 布尔类型的假:""/0/[]/()/{}/False/None
  • 布尔类型的真:除了以上的假都是真(True/1)
>>> 4>3
True
>>> 4<3
False
>>> bool([])
False
>>> bool(())
False
>>> bool({})
False
>>> bool(0)
False
>>> bool("")
False

 

 

此处还可以用isinstance来判断:

>>> a=100
>>> isinstance(a,int)
True

type和isinstance的区别?

 

 

数值运算:+、-、*、/、%、//、**

 

>>>5 + 4  # 加法
9
>>> 4.3 - 2 # 减法
2.3
>>> 3 * 7  # 乘法
21
>>> 10 / 8  # 真除,得到一个浮点数
1.25
>>> 10 // 8 # 整除(向下取整)
1
>>> 10 % 8 # 取余 
2
>>> 2 ** 5 # 乘方
32


#运算函数math包
>>> import math
>>> math.sqrt(4)  #开方
2.0
>>> math.pow(2,4)  #次方
16.0
>>> math.pi    #pi
3.141592653589793

>>> math.ceil(4.01)  #向上取整
5

>>> divmod(9,4)  #同时取整和取余
(2, 1)

*divmod() 函数把除数和余数运算结果结合起来,返回一个包含商和余数的元组(a // b, a % b)

 

 

 比较运算:==、!=、>、<、>=、<=

>>> a = 21
>>> b = 10
>>> c = 0
>>>
... if ( a == b ):
...    print ("1 - a 等于 b")
... else:
...    print ("1 - a 不等于 b")
...
1 - a 不等于 b
>>> if ( a != b ):
...    print ("2 - a 不等于 b")
... else:
...    print ("2 - a 等于 b")
...
2 - a 不等于 b

 

 

赋值运算:=、+=、-=、*=、/=、%=、//=、%=

>>> a = 21
>>> b = 10
>>> c = 0
>>> c = a + b
>>> print ("1 - c 的值为:", c)
1 - c 的值为: 31
>>> c += a
>>> print ("2 - c 的值为:", c)
2 - c 的值为: 52
>>> c *= a
>>> print ("3 - c 的值为:", c)
3 - c 的值为: 1092
>>> c /= a
>>> print ("4 - c 的值为:", c)
4 - c 的值为: 52.0

 

位运算:

& 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 (a & b) 输出结果 12 ,二进制解释: 0000 1100
| 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 (a | b) 输出结果 61 ,二进制解释: 0011 1101
^ 按位异或运算符:当两对应的二进位相异时,结果为1 (a ^ b) 输出结果 49 ,二进制解释: 0011 0001
~ 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1。~x 类似于 -x-1 (~a ) 输出结果 -61 ,二进制解释: 1100 0011, 在一个有符号二进制数的补码形式。
<< 左移动运算符:运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。 a << 2 输出结果 240 ,二进制解释: 1111 0000
>> 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数 a >> 2 输出结果 15 ,二进制解释: 0000 1111

 

逻辑运算:and、or、not

 练习:

1.输出1000以内的能被2、3、5同时整除的数。
2.输出1000以内的能被2、3、5中任意一个整除的数。每10个数为一行输出。

3.判断一个年份是否是闰年

1.
>>> for i in range(1,1000):
...     if i%2==0 and i%3==0 and i%5==0:
...         print(i)
...


2.

>>> count = 0
>>> for i in range(1,10001):
...     if i % 2 ==0 or i % 3 ==0 or i % 5 ==0:
...         print(i,end=" ")
...         count+=1
...         if count%10==0:
...             print("")

 

3.
>>> year =int(input("请输入一个年份:"))
请输入一个年份:2000
>>>
>>> if (year%4 == 0 and year%100 != 0) or year%400 == 0:
...     print("%s 是闰年" %year)
...
2000 是闰年
 

 

 

 成员运算:in、not in

 

身份运算:is、is not

is is 是判断两个标识符是不是引用自一个对象 x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False
is not is not 是判断两个标识符是不是引用自不同对象 x is not y , 类似 id(a) != id(b)。如果引用的不是同一个对象则返回结果 True,否则返回 False。

注: id() 函数用于获取对象内存地址。

 

 

 

另外五种类型会单独来写:

>>> print(type('road'))
<class 'str'>
>>> print(type([1,2,3]))
<class 'list'>
>>> print(type((1,2,3)))
<class 'tuple'>
>>> print(type({"a":1,"b":2}))
<class 'dict'>
>>> print(type(set([3,4])))
<class 'set'>

 

posted on 2019-10-01 20:38  腿短毛不多  阅读(325)  评论(0编辑  收藏  举报