小白学语言之Python(数据类型和变量,常量)

 

小编又来了,python语言学习的第三周,我们开始了解关于python的一些基础,数据类型和常量,变量...



[知东智西]致力于网络最新科技,总结技术资料,分享热门资讯,为广大学者和创客打造一个多方位的信息分享平台。

编辑:孔小雨


【本周我们来介绍python的一些基础知识,数据类型和变量,常量的概念】

 
数据类型

【计算机,顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值。但是,计算机能处理的远不止数值,还可以处理文本、图形、音频、视频、网页等各种各样的数据,不同的数据,需要定义不同的数据类型。】

在Python中,能够直接处理的数据类型有以下几种:

整数

Python可以处理任意大小的整数,当然包括负整数。

在程序中的表示方法和数学上的写法一模一样,例如:
1
100
-8080
0


浮点数

浮点数也就是小数,之所以称为浮点数,是因为按照科学记数法表示时,一个浮点数的小数点位置是可变的,如,1.23x109和12.3x108是完全相等的

浮点数可以用数学写法,如
1.23
3.14
-9.01。


但是对于很大或很小的浮点数,就必须用科学计数法表示,把10用e替代,1.23x109就是
1.23e9
,或者
12.3e8
,0.000012可以写成
1.2e-5。
[img]http://img02.store.sogou.com/net/a/05/link?appid=100520091&url=http://mmbiz.qpic.cn/mmbiz/lU9l0QA0Yts9xdFBD3ZGAzNlTsD6sibR9gvrnuNTI2OJwavyBv8lIRw8rYINRF4OHc5EcgnWYvjhhArGa3Cjcyg/0?wx_fmt=gif[/img]
这里补充两个关于整数运算与浮点数的小知识


➢Python的整数没有大小限制,而某些语言的整数根据其存储长度是有大小限制的,例如Java对32位整数的范围限制在
-2147483648
-
2147483647


Python的浮点数也没有大小限制,但是超出一定范围就直接表示为
inf
(无限大)。


➢在Python中,有两种除法,一种除法是
/




★ [/b]/
除法计算结果是浮点数

即使是两个整数恰好整除,结果也是浮点数:


还有一种除法是
//
,称为地板除,两个整数的除法仍然是整数:


你没有看错,整数的地板除
//
永远是整数,即使除不尽。

要做精确的除法,使用
/
就可以。

因为
//
除法只取结果的整数部分,所以Python还提供一个余数运算,可以得到两个整数相除的余数:



➲[b]字符串


字符串是以单引号 ' 或双引号 " 括起来的任意文本,比如'abc',"xyz"。

【注意】


' '或 " "本身只是一种表示方式,不是字符串的一部分,因此,字符串'abc'只有a,b,c这3个字符。

➢那么,‘ ’和“ ”在python中有什么区别呢 
“abc",'abc',实质上 没有区别,但有一个关于两者的小技巧:
当你编写的文本中含有单引号时,
机器会混乱字符串的单引号与文本的单引号,
那么这时你便可以使用双引号括起字符串。
例:



➢那么我们遇到字符串里既包含‘又包含“ 该怎么办呢?
这里我们可以用转义字符

来标识,用法很简单。
例:



➲布尔值

布尔值和布尔代数的表示完全一致,一个布尔值只有
True
False
两种值,要么是
True
,要么是
False
,在Python中,可以直接用
True
False
表示布尔值(请注意大小写),也可以通过布尔运算计算出来,例:



➢布尔值可以用
and
or
not
运算。

and
运算是 与 运算,只有所有都为
True
and
运算结果才是
True




or
运算是或运算,只要其中有一个为
True
or
运算结果就是
True




not
运算是非运算,它是一个单目运算符,把
True
变成
False
False
变成
True




➲空值

空值是Python里一个特殊的值,用
None
表示。
None
不能理解为
0
,因为
0
是有意义的,而
None
是一个特殊的空值。

此外,Python还提供了列表、字典等多种数据类型,还允许创建自定义数据类型,我们后面会继续讲到。


变量 

变量的概念基本上和初中代数的方程变量是一致的,只是在计算机程序中,变量不仅可以是数字,还可以是任意数据类型。

变量在程序中就是用一个变量名表示了,变量名必须是大小写英文、数字和
_
的组合,且不能用数字开头。


常量 

所谓常量就是不能变的变量。


知识点补充

在Python中,等号 
是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量。


例如:(#表示注释)


a = 123    # a是整数print(a) 
a = 'ABC'  # a变为字符串print(a)


这种变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错。

例如Java是静态语言,赋值语句如下(// 表示注释):


int a = 123; // a是整数类型变量


a = "ABC";   // 错误:不能把字符串赋给整型变量


和静态语言相比,动态语言更灵活,就是这个原因。

请不要把赋值语句的等号等同于数学的等号。

比如下面的代码:


x = 10


x = x + 2


如果从数学上理解
x = x + 2
那无论如何是不成立的,在程序中,赋值语句先计算右侧的表达式
x + 2
,得到结果
12
,再赋给变量
x
。由于
x
之前的值是
10
,重新赋值后,
x
的值变成
12


最后,理解变量在计算机内存中的表示也非常重要。

当我们写:
a = 'ABC'
时,


Python解释器干了两件事情:

  1. 在内存中创建了一个
    'ABC'
    的字符串;
  2. 在内存中创建了一个名为
    a
    的变量,并把它指向
    'ABC'
也可以把一个变量
a
赋值给另一个变量
b
,这个操作实际上是把变量
b
指向变量
a
所指向的数据,例如下面的代码:


a = 'ABC'


b = a


a = 'XYZ'


print(b)


最后一行打印出变量
b
的内容到底是
'ABC'
还是
'XYZ'?


如果从数学意义上理解,就会错误地得出
b
a
相同,也应该是
'XYZ'
,但实际上
b
的值是
'ABC'
,让我们一行一行地执行代码,就可以看到到底发生了什么事:


执行
a = 'ABC'
,解释器创建了字符串
'ABC'
和变量
a
,并把
a
指向
'ABC'





执行
b = a
,解释器创建了变量
b
,并把
b
指向
a
指向的字符串
'ABC'





执行
a = 'XYZ'
,解释器创建了字符串'XYZ',并把
a
的指向改为
'XYZ'
,但
b
并没有更改:





所以,最后打印变量
b
的结果自然是
'ABC'
了。



!又到了本周布置作业的时间啦
请打印出以下变量:

n = 123
f = 456.789
s1 = 'Hello, world'
s2 = 'Hello, 'Adam''
声明:该平台为学生自主运营,如果内容侵犯了您的版权,请在微信端留言,我们会马上修改或删除,感谢您的支持与理解!


    关注 知东智西


微信扫一扫关注公众号

0 个评论

要回复文章请先登录注册