2|2 、数据类型和基本运算

Lesson_2 【1】注释
每个语言中都有注释,包括我们小时候学的语文课中有很多的文言文它们都有注释;那么我们可以得出结论,python的注释就是把代码描述出来,让其他人更快的去理解。
前面我们提到过注释,被注释的内容就是不被程序解析的文本域。

#井号代表单行注释''' 三个单引号表示多行注释 三个单引号表示多行注释 三个单引号表示多行注释 '''""" 三个双引号表示多行注释 三个双引号表示多行注释 三个双引号表示多行注释 """

【2】舒克和贝塔( print和input )
print和input一个是输出一个是输入,这两个函数难舍难分。
#print()的作用就是向屏幕上打印输出内容print('hello 1000phone')print('hello 1000phone','hello 1000phone')print(12)print(13,14)

print的参数’end‘,我们上面的print输出完以后每次都会换行,这就是end导致的,end的默认参数是’\n‘就是回车的意思。
print('hello word',end=' ')#表示以空格拼接 print('hello shanghai',end=' =>') #表示以=>(箭头)拼接>>>hello word hello shanghai =>

input就是接受我们输入的信息的,例如在我们输入账号和密码的时候,在输入我们的手机号的时候。
name = input('随便输入一段话:')>>>随便输入一段话:你好python >>>你好python

【3】标识符
1、什么是标识符?标识符就是一段字符提示:字符串未必是标识符
2、标识符的规则
1、只能由字母、数字、下划线组成,且不能以数字开头。 2、不能是python的关键字 import keyword print(keyword.kwlist) 可以在python脚本中引入keyword查看 3、区分大小写,见名知意,比如声明一个(用户账号)的变量 :username

4、标识符的作用就是给变量、函数、类等等命名的。
提示:在python3中非 ASCII 标识符也是允许的
【4】闲聊数据类型
计算机顾名思义就是做数学计算使用的,因此计算机理所当然可以处理各种数值。
但是计算机远不止能处理数值,还可以处理文本、图形、音频、视频等其它数据,不同的数据就需要不同的类型。
我们python的中的变量是没有数据类型的,python中的变量更加像是标签想贴哪儿就贴哪儿,通过这个标签,就可以找到变量在内存中对应的存放位置。
python的数据类型有 number(数字):int(整型或者说正整数和负整数)、float(浮点型或者说小数)、complex(复数) string(字符串) boolean(布尔值) none(空值) list(列表) tuple(元祖) dict(字典) set(集合)

第四章 在成为高手之前我们我们必须要知道的一些基础知识
【1】变量和常量
当你把一个赋值给一个名字时,它会储存在内存中,把这块内存空间成为变量,
在大多数语言中,都把这种行为称为’给变量赋值‘或’或把值存在变量中‘。
不过,python不同于其它语言,python并不是把值存在变量中,而是把名字’贴‘在’值‘上面。
所以有些python的程序员会说python没有变量,自由名字,但是变量本来就是一个名字,可以找到我们想要的东西。
常量就是恒久不变的变量,它在.py文件执行过程中就会自动加载到内存的静态区中,遗憾的是,python中没有常量的定义。
看个例子:
name = '李连杰' print(name)>>>李连杰name = '吴京' print(name)>>>吴京 #name是变量 等于号 后面的是值

为什么叫变量不叫衡量?因为它是可变的!再看一个例子:
x = 3 x = 5 y = 8 z = x + y print(z)>>>13 #我先给x赋值了一个3,然后又给它赋值了一个5(这个时候3就被5替换了), 接下来创建一个y,给它初始化并赋值一个8,最后创建一个变量z,它的值是变量和y的和。

同样运用到字符串中:
name1 = '梁山伯' name2 = '祝英台' name3 = name1 + name2 print(name3)>>> 梁山伯祝英台 #再次提示这种字符串相加叫拼接,不是拼爹

需要注意的地方:
1、在使用之前,需要对它赋值。 2、变量名可以包括字母、数字下划线,但变量名不能以数字开头。 3、等号(=)地赋值的意思,左边是名字,右边是值,不可写反了。 4、变量的名字理论上可以取任何合法的名字,但作为一个优秀的程序员,请尽量给变量一个专业一点的名字。

变量是指向内存分配给 值 得空间的,那么我们怎么知道这个值存储的位置了?
使用BIF id() 它的作用是查找 值在内存中的地址,看下面的例子:
num1 = 3 num2 = 3print(id(num1),id(num2))>>>4297636960 4297636960#我们可以发现num1,和num2 的结果是一样,那么我们可以得到一个结论,num1和num2指向内存中的同一个地址。

关于类型的信息 虽然我们的变量是没有类型的,但是我们的 值 是有类型区分的,怎么查看值得类型了?
使用BIF type() 作用是获取值得类型:
str = 'abcd' sn= Noneint = 123flt = 1.22com = 234jboo = Trueprint(str,sn,int,flt,com,boo) print(type(str),type(sn),type(int),type(flt),type(com),type(boo))>>>abcd None 123 1.22 234j True >>>

通过上面的例子可以看出python的数据类型有
数字(number)、字符型(string)、布尔型(boolean)、None(空值)
我们后面还要学:
列表(list)、tuple(元祖)、dict(字典)、set(集合)
这是我们python的8种数据类型
还可以使用 isinstance()判断变量值与类型是否相等,返回布尔值
stri = '123'print(isinstance(stri,int)) False print(isinstance(stri,str)) True>>>False >>>True #第一个参数是我们要分辨的变量,第二个参数是我们需要判断的类型,它只会返回True和False

【2】Number(数字)
我们在前面提到过我们的number类型分为 整型、浮点型、复数
整型说白了就是整数,python3的整型已经与长整型进行了无缝结合,
现在的python3的整型类似于Java的BigInteger类型,它的长度不受限制,
如果非要有个限制,那就只限于计算机的虚拟内存总数了。所以python3很容易进行大数计算。
num1 = 10 num2 = num1 print(id(num2)) # 连续定义多个变量 num3 = num4 = num5 = 1 print(num3, num4, num5)#交互式赋值定义变量 num6, num7 = 6, 7 print(num6, num7)

【3】float(浮点数)
浮点数就是平时说的小数,例如圆周率就是浮点型,python中的整型和浮点型的唯一区分方式就是看有没有小数点。
谈到了浮点型,不得不说下e记法。也就是我们平时说的科学计数法,用于表示特别大和特别小的数:
num = 0.000025 print(num)>>>2.5e-05num = 25000 print(format(num,'.1e'))>>>2.5e+04#python3在正整数输出的时候默认会原样输出,所以使用format()函数转换成科学计数法。 format(num,'.1e')第二个参数是'.1e'表示保留小数点后面的1个小数部分。 format(num,'e')如果是”e“会默认保留多个小数部分。

【4】复数(了解)
一个实数和一个虚数的组合构成一个复数。
一个复数是一对有序浮点数(x, y)。表示为x + yj,其中x是实数部分,y是虚数部分。
渐渐的复数在日常运算,机械,电子等行业获得了广泛的应用。
由于一些研究人员不断的重复制造用于复数运算的工具,
在很久以前的Python1.4 版本里,复数终于成为一个真正的Python 数据类型。
下面是 Python 语言中有关复数的几个概念:
虚数不能单独存在,它们总是和一个值为 0.0 的实数部分一起来构成一个复数。 复数由实数部分和虚数部分构成 表示虚数的语法: real+imagj 实数部分和虚数部分都是浮点数 虚数部分必须有后缀j或J。

复数的内建属性
复数对象拥有数据属性,分别为该复数的实部和虚部。复数还拥有conjugate 方法,调用它可以返回该复数的共轭复数对象。
复数属性:
属性描述 num.real该复数的实部 num num.imag该复数的虚部 num.conjugate()返回该复数的共轭复数(实数不变,虚数互为相反数)

c=2.3+2.5j print(c.real) print(c.imag) print(c.conjugate())>>>2.3 >>>2.5 >(2.3-2.5j)

【5】类型的转换
接下来介绍几个跟数据类型紧密相关的函数:int()、float()、str()
int(): int()的作用是将一个字符串或者一个浮点数转换成一个整数
a = '123'b = 3.1415926c = 5.9print(int(a),end=',') print(int(b),end=',') print(int(c))>>>123,3,5#通过结果可以发现int在转换浮点型的时候,python会采取’截断‘处理,就是把小数点后面的数据直接砍掉,而不是四舍五入;

注意:
a = '4a' print(int(a))#如果这个字符串里面不是纯数字字符那么就会报错。>>>Traceback (most recent call last): File "/Users/ruidong/PycharmProjects/project/demo.py", line 7, in print(int(a),end=',') ValueError: invalid literal for int() with base 10: 'q'

float(): float() 的作用是把一个字符串或整数转换成浮点数。
a = 520b = '520'c = '980'print(float(a)) print(float(b + c))>>>520.0 >>>520980.0#python进行浮点型转换的时候默认在后面加了一个’.0‘

str(): str()的作用是将一个数或任何类型转换成一个字符串
a = str(3.4)b = str(89)c = 5e15print(a,b,str(c))>>>3.4 89 5000000000000000.0#在被转类型的两边加上了引号

【6】数学功能
python3的数学功能是强大的,但是再强大的功能也要去熟悉它的用法和操作。
首先我们要在python的编译器中输入
import math#引入数学库print(math)#没有报错就表示引入正常

abs()绝对值
a1 = -10 a2 = abs(a1) print(a2)>>>10

比较两个数的大小
a3 = 100 a4 = 9 print((a3>a4)-(a3>>1

max()返回一个最大的值
print(max(1,2,3,4,5,6,7,8))>>>8

min()返回一个最小的值
print(min(1,2,3,4,5,6,7,8))>>>1

pow(x,y)求x的y次方
print(pow(2, 5))>>>32

round(x,y)四舍五入 x表示数字 y表示保留几位小数
print(round(3.456)) print(round(3.556)) print(round(3.456, 2)) print(round(3.546, 1))>>>3 >>>4 >>>3.46 >>>3.5

math.ceil()向上取整
print(math.ceil(18.1)) print(math.ceil(18.9))>>>19 >>>19

math.floor()向下取整
print(math.floor(18.1)) print(math.floor(18.9))>>>18 >>>18

math.modf()返回小数部分与整数部分
print(math.modf(22.3))>>>(0.3000000000000007, 22.0)

math.sqrt()开放 返回浮点类型
print(math.sqrt(16))>>>4.0

【7】随机数
随机数在我们日常的生活中也是比较常见的,比如说我们手机的验证码等。
random.choise() 从序列的元素中随机挑选一个元素
print(random.choice([1,3,5,7,9])) print(random.choice(range(5)))#range(5) == [0,1,2,3,4] print(random.choice("sunck"))#"sunck"== ["s","u","n","c","k"] print(random.choice(range(10)) + 1)

random.randrange() 从指定范围内,按指定的基数递增的集合中选取一个随机数
#random.randrange([start,] stop[, step]) #start--指定范围的开始值,包含在范围内,默认是0 #stop--指定范围的结束之,不包含在范围内 #step--指定的递增基数,默认是1 print(random.randrange(1, 100, 2)) #从0-99选取一个随机数 print(random.randrange(100))

random.random() 随机生产[0,1)之间的数(浮点数)
print(random.random())

random.shuffle()将序列的所有元素随机排序
list = [1,2,3,4,5] random.shuffle(list) print(list)

random.uniform(x,y)随机生产一个实数,他在[x,y]范围
print(random.uniform(3,9))

【8】三角函数(了解)
我们为什么不把三角函数放在 数学功能里面讲了,因为在商业开发中很少会用到三角函数。

正弦:在Rt△ABC中,∠C=90°,我们把锐角A的对边与斜边的比叫做∠A的正弦(sine),记作sinA,即sinA=∠A的对边/斜边=a/c
sin(A) #返回A的正玄值

余弦:我们把∠A的邻边与斜边的比叫做∠A的余弦(cosine),记作cosA,即cosA=∠A的邻边/斜边=b/c
cos(A) #返回A的余玄值

cosA=∠A的邻边/斜边=b/c
正切:把∠A的对边与邻边的比叫做∠A的正切(tangent),记作tanA,即
tanA=∠A的对边/∠A的邻边=a/b对于tanA还有一个公式tanA=sinA/cosA

tan(A)#返回A的正切值

第五章 【1】算数操作符
和大多数语言一样,python的算数操作符绝大部分能被我们所理解,注意不是全部。
+-*/%**//加减乘除取模求幂取整 (取余) (math.pow)

前面四个应该不用多说了,大名鼎鼎的四则运算。
num1 = 5 num2 = 3 print(num1 + num2) print(num1 - num2) print(num1 * num2) print(num1 / num2) print(num1 % num2) print(num1 ** num2)#5^3pow(5, 3) print(num1 // num2)>>>8 >>>2 >>>15 >>>1.6666666666666667 >>>2 >>>125 >>>1

【2】赋值运算符和赋值运算表达式
赋值运算符 =
赋值运算表达式
格式:变量 = 表达式
功能:计算了等号右侧“表达式”的值,并赋值给等号左侧的变量
值:赋值结束后变量的
num3 = 10 num4 = num3 + 20print(num3,num4)>>>10 30

【3】复合运算符
复合运算符 +=a += ba = a + b -=a -= ba = a - b *=a *= ba = a * b /=a /= ba = a / b %=a %= ba = a % b **=a **= ba = a ** b //=a //= ba = a // b

【4】优先级问题
当一个表达式存在多个运算符的时候,就可能发生不知道先运行谁的情况;
比如小学数学规定,先括号在乘除,加减是最低,这就是优先级。
例如:
-3 * 2 + 5 / -2 -4相当于:(-3) * 2 + 5 / (-2) -4 #这个大家很容易理解

python有一个特殊的乘法,双星号(**)幂运算,
例如:
3 ** 2星号左侧是底数,星号右侧是指数,这叫做3的2次幂,或者3的2次方

【2|2 、数据类型和基本运算】因为幂运算操作符和一元操作符的优先级关系比较特别,幂运算操作符比期左侧的一元操作符优先级高,比其右侧的医院操作符优先级低。
-3 ** 2>>>93 ** -2>>>0.1111111111111111

    推荐阅读