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 = 3

print(id(num1),id(num2))


>>>4297636960 4297636960

#我们可以发现num1,和num2 的结果是一样,那么我们可以得到一个结论,num1和num2指向内存中的同一个地址。

关于类型的信息

虽然我们的变量是没有类型的,但是我们的 值 是有类型区分的,怎么查看值得类型了?

使用BIF type() 作用是获取值得类型:


str = 'abcd' 

sn  = None

int = 123

flt = 1.22

com = 234j

boo = True

print(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-05

num = 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.1415926

c = 5.9

print(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 = 520

b = '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 = 5e15

print(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^3  pow(5, 3)
print(num1 // num2)



>>>8
>>>2
>>>15
>>>1.6666666666666667
>>>2
>>>125
>>>1

【2】赋值运算符和赋值运算表达式

赋值运算符 =

赋值运算表达式
格式:变量 = 表达式
功能:计算了等号右侧“表达式”的值,并赋值给等号左侧的变量
值:赋值结束后变量的


num3 = 10
num4 = num3 + 20

print(num3,num4)

>>>10 30

【3】复合运算符


复合运算符
+=   a += b     a = a + b
-=   a -= b     a = a - b
*=   a *= b     a = a * b
/=   a /= b     a = a / b
%=   a %= b     a = a % b
**=   a **= b     a = a ** b
//=   a //= b     a = a // b

【4】优先级问题

当一个表达式存在多个运算符的时候,就可能发生不知道先运行谁的情况;

比如小学数学规定,先括号在乘除,加减是最低,这就是优先级。

例如:


-3 * 2 + 5 / -2 -4

相当于:

(-3) * 2 + 5 / (-2) -4 

#这个大家很容易理解

python有一个特殊的乘法,双星号(**)幂运算,

例如:

3 ** 2

星号左侧是底数,星号右侧是指数,这叫做3的2次幂,或者3的2次方

因为幂运算操作符和一元操作符的优先级关系比较特别,幂运算操作符比期左侧的一元操作符优先级高,比其右侧的医院操作符优先级低。

-3 ** 2

>>>9

3 ** -2

>>>0.1111111111111111

你可能感兴趣的:(2 、数据类型和基本运算)