数据类型
Python3 中有六个标准的数据类型:
- Number(数字)
- String(字符串)
- List(列表)
- Tuple(元组)
- Sets(集合)
- Dictionary(字典)
Python3 的六个标准数据类型中:
不可变数据(四个):Number(数字)、String(字符串)、Tuple(元组)、Sets(集合);
可变数据(两个):List(列表)、Dictionary(字典)。
print语句
print语句也可以跟上多个字符串,用逗号“,”隔开,就可以连成一串输出,print会依次打印每个字符串,遇到逗号“,”会输出一个空格,因此,输出的字符串是这样拼起来的
>>> print 300
300 #运行结果
>>> print 100 + 200
300 #运行结果
变量
变量名
在Python程序中,变量是用一个变量名表示,变量名必须是大小写英文、数字和下划线"_"的组合,且不能用数字开头
> a = 1
> 变量a是一个整数。
t_007 = 'T007'
变量t_007是一个字符串。
赋值
在Python中,等号=是赋值语句,可以把任意数据类型赋值给变量,同一个变量可以反复赋值,而且可以是不同类型的变量
a = 123 # a是整数
print a
a = 'imooc' # a变为字符串
print a
这种变量本身类型不固定的语言称之为动态语言,与之对应的是静态语言。静态语言在定义变量时必须指定变量类型,如果赋值的时候类型不匹配,就会报错。例如Java是静态语言,赋值语句如下(// 表示注释):
int a = 123; // a是整数类型变量
a = "mooc"; // 错误:不能把字符串赋给整型变量
和静态语言相比,动态语言更灵活,就是这个原因。
a = 'ABC'
b = a
a = 'XYZ'
print b
输出结果:ABC
- 练习
等差数列可以定义为每一项与它的前一项的差等于一个常数,可以用变量 x1 表示等差数列的第一项,用 d 表示公差,请计算数列1 4 7 10 13 16 19 …前 100 项的和
d=1
c=100
sum=0
while c > 0:
sum=sum+d
d=d+3
c=c-1
print(sum)
字符串
转义字符
前面我们讲解了什么是字符串。字符串可以用’'或者"“括起来表示。
如果字符串本身包含’怎么办?比如我们要表示字符串 I’m OK ,这时,可以用” "括起来表示:
"I'm OK"
类似的,如果字符串包含",我们就可以用’ '括起来表示:
'Learn "Python" in imooc'
如果字符串既包含’又包含"怎么办?
这个时候,就需要对字符串的某些特殊字符进行“转义”,Python字符串用\进行转义。
要表示字符串 Bob said “I’m OK”.
由于 ’ 和 " 会引起歧义,因此,我们在它前面插入一个\表示这是一个普通字符,不代表字符串的起始,因此,这个字符串又可以表示为
'Bob said \"I\'m OK\".'
\n 表示换行
\t 表示一个制表符
\ 表示 \ 字符本身
raw字符串与多行字符串
如果一个字符串包含很多需要转义的字符,对每一个字符都进行转义会很麻烦。为了避免这种情况,我们可以在字符串前面加个前缀 r ,表示这是一个 raw 字符串,里面的字符就不需要转义了。例如:r’(_)/ (_)/’
str=r'\(~_~)/ \(~_~)/'
print(str)
输出: \(_)/ (_)/
但是 r ’ … ’ 表示法不能表示多行字符串,也不能表示包含’和 "的字符串(为什么?)
如果要表示多行字符串,可以用 ‘’’…’’’
str='''Line 1
Line 2
Line 3'''
print(str)
输出:
Line 1
Line 2
Line 3
上面这个字符串的表示方法和下面的是完全一样的:
'Line 1\nLine 2\nLine 3'
还可以 在多行字符串前面添加 r ,把这个多行字符串也变成一个raw字符串:
r''' Python is created by "Guido".
It is free and easy to learn.
Let's start learn Python in imooc!'''
输出语句中夹杂变量的方法:
my_name = 'Zed A. Shaw'
my_eyes = 'Blue'
my_hair = 'Brown'
print "Let's talk about %s." % my_name
print "He's got %s eyes and %s hair." % (my_eyes, my_hair)
字符串的嵌套
hilarious = False
joke_evaluation = "Isn't that joke so funny?! %r"
print joke_evaluation % hilarious
输出:
Isn't that joke so funny?! False
Q: %r 和 %s有什么不同?
用%r显示的是变量“原始”的数据值,%r在打印的时候能够重现它代表的对象,但其他的符号用来给用户显示变量值。看下面的例子理解一下:
text = "I am %d years old." % 22
print "I said: %s." % text
print "I said: %r." % text
返回的结果:
I said: I am 22 years old..
I said: 'I am 22 years old.'. // %r 给字符串加了单引号
Unicode字符串
Python在后来添加了对Unicode的支持,以Unicode表示的字符串用u’…‘表示,比如:print u’中文’
注意: 不加 u ,中文就不能正常显示。
Unicode字符串除了多了一个 u 之外,与普通字符串没啥区别,转义字符和多行表示法仍然有效
u'''第一行
第二行'''
raw+多行:
ur'''Python的Unicode字符串支持"中文",
"日文",
"韩文"等多种语言'''
如果中文字符串在Python环境下遇到 UnicodeDecodeError,这是因为.py文件保存的格式有问题。可以在第一行添加注释
# -*- coding: utf-8 -*-
//u和上面这一句相同的意思,不要重复添加
布尔类型
我们已经了解了Python支持布尔类型的数据,布尔类型只有True和False两种值,但是布尔类型有以下几种运算:
与运算:只有两个布尔值都为 True 时,计算结果才为 True。
True and True # ==> True
True and False # ==> False
False and True # ==> False
False and False # ==> False
或运算:只要有一个布尔值为 True,计算结果就是 True。
True or True # ==> True
True or False # ==> True
False or True # ==> True
False or False # ==> False
非运算:把True变为False,或者把False变为True:
not True # ==> False
not False # ==> True
a = True
print a and 'a=T' or 'a=F'
计算结果不是布尔类型,而是字符串 ‘a=T’,这是为什么呢?
因为Python把0、空字符串’'和None看成 False,其他数值和非空字符串都看成 True
rue and ‘a=T’ 计算结果是 ‘a=T’ 继续计算 ‘a=T’ or ‘a=F’ 计算结果还是 ‘a=T’
要解释上述结果,又涉及到 and 和 or 运算的一条重要法则: 短路计算。
- 在计算 a and b 时,如果 a 是 False,则根据与运算法则,整个结果必定为 False,因此返回 a;如果 a 是 True,则整个计算结果必定取决与 b,因此返回 b。
- 在计算 a or b 时,如果 a 是 True,则根据或运算法则,整个计算结果必定为 True,因此返回 a;如果 a 是 False,则整个计算结果必定取决于 b,因此返回 b。
所以Python解释器在做布尔运算时,只要能提前确定计算结果,它就不会往后算了,直接返回结果。