链式赋值
同一个对象赋值给多个变量
x = y = 123 相当于 x = 123 ; y = 123
系列解包赋值
python不支持常量,没有语法规则限制改变一个常量的值。我们只能约定常量的命名规则,以及在程序的逻辑上对常量的值作出修改
Python中最基本的数据类型:
1.整型:整数,2345、15
2.浮点型:小数,1.3、13.446
3.布尔值:True、False
4.字符串类型:anfadn、我的名字
Python支持证书和浮点数,我们可以对数字做如下
运算:
加 +
减 -
乘 *
浮点数除法 /
整数除法 //
取余数 %
幂 **
除数为0,会产生异常:ZeroDivisionError:division by zero
使用divmod()函数同时得到商和余数:
divmod(13,3)
得到结果(4,1)
divmod()是一个函数,返回的是一个元组
Python中,除10进制,还有其他三种进制:
Python中,除10进制,还有其他三种进制:
0b,二进制 0 1
0o,八进制 0 1 2 3 4 5 6 7
0x,十六进制 0 1 2 3 4 5 6 7 8 9 a b c d e f
使用int()实现类型转换:
1.浮点数直接社区小数部分。如:int(9.9)结果是:9
2.布尔值True转为1,False转为0
3.字符串符合整数格式的,可以直接转换为整数
自动转型:
整数和浮点数混合运算时,表达式结果自动转型成浮点数。比如2+8.0的结果是10.0
整数可以有多大?
Python2中,int是32位,可以存储从-2147483648到2147483647的整数(约正负21亿)。Long类型是64位,可以存储-2^63--2^63-1之间的数值。
Python3中,int可以存储任意大小的整数。long被取消。我们甚至可以存储更大值
Googol也是Google最初的名字,这也是Google最初的含义。 googol等于 10**100
Python3中可以做超大数的计算,而不会造成“整数溢出”,这也是Python特别适合科学运算的特点。
浮点数,称为float。
浮点数用科学计数法表示。比如134E-2,这些数字在内存中也是按照科学计数法存储。
类型转换和四舍五入
1.类似于int(),我们也可使使用float()将其他类型转化成浮点数。-生成一个新的浮点数对象
2.整数和浮点数混合运算时,表达式结果自动转型成浮点数
3.round(value)可以换回四舍五入的值
注:不改变原有的值,而是产生新的值
增强型赋值运算符
一个增强运算符内部符号之间不能用增加空格,否则报错
计算机中时间的表示是从“1970年1月日的00:00:00”开始,以毫秒(1/1000秒)进行计算。我们也把1970年这个时刻成为“unix时间点”。
这样,我们就把时间全部用数字来表示了。
python中可以通过time.time()获得当前时刻,返回的值是以秒为单位,带微秒(1/1000毫秒)精度的浮点值。例如:1503167364.8566
复习turtle、运算符、导入模块
注意不要用中文括号
#导入turtle和math模块
import turtle
import math
#定义坐标点
x1,y1 = 100,100
x2,y2 = 100,-100
x3,y3 = -100,-100
x4,y4 = -100,100
#绘制线条
turtle.penup()
turtle.goto(x1,y1)
turtle.pendown()
turtle.goto(x2,y2)
turtle.goto(x3,y3)
turtle.goto(x4,y4)
#计算终点和起点的距离
distance = math.sqrt((x4-x1)**2+(y4-y1)**2)
turtle.write(distance)
布尔值
Python2中没有布尔值,直接用数字0表示Flase,用数字1表示True
Python3中,把True和False定义为1和0,是指可以和数字相加。
>>> b = True
>>> b+3
4
比较运算符
同一运算符用于比较两个对象的存储单元,实际比较的是对象的地址。
>>>a=1000
>>>b=1000
>>>a==b
True
>>>a is b
False
>> id(a)
46764560
>>> id(b
4676521
(1)is与==区别:
is用于判断两个变量引用对象是否为同一个,既比较对象的地址
==用于判断引用变量引用对象的值是否相等,默认调用对象的eq()方法。
(2)整数缓存问题
·整数缓存问题Python仅仅对比较小的整数对象进行缓存(范围为【-5,256】)缓存起来,而并非是所有整数对象。需要注意的是,这仅仅是在命令行中执行,而在 Pycharm或者保存为文件执行,结果是不样的,这是因为解释器做了一部分优化(范围是【-5,任意正整数】)。
(3)总结
1、is比较两个对象的id值是否相等,即比较是否指向同一个内存地址;
2、==比较的是两个对象的内容是否相等,即比较值是否相等
3、小整数对象【-5,256】在全局解释器范围内被放入缓存供重复使用
4、is运算符比==效率高,在变量和None进行比较时,应该使用is
字符串基本特点
字符串的本质是:字符序列。 Python的字符串是不可变的,我们无法对原字符串做任何修改。但,可以将字符串的一部分复制到新创建的字符串,达到“看起来修改”的效果。
Python不支持单字符类型,单字符也是作为一个字符串使用的。
字符串的编码
Python3直接支持 Unicode可以表示世界上任何书面语言的字符. Python3的字符默认就是16位 Unicode编码,ASCⅡ码是 Unicode编码的子集 使用内置函数ord0可以把字符转换成对应的 Unicode码;
使用内置函数chr0可以把十进制数字转换成对应的字符。
引号创建字符串
我们可以通过单引号或双引号创建字符串。例如:a=‘abc’;b="sxt”
使用两种引号的好处是可以创建本身就包含引号的字符串,而不用使用转义字符。例如:
>>>a=''Im a teacher!''
>> print(a)
I'm a teacher!
>>>b='my _name is''TOM'''
>>>print(b)
my name is''TOM''
连续三个单引号或三个双引号,可以帮助我们创建多行字符串。例如:
>>>resume ='''name= ''gaoqi''
company="sxt"
age=18
lover="Tom"'''
>> print(resume)
name= ''gaoqi''
company="sxt''
age=18
lover="Tom''
空字符串和len()函数
Python允许空字符串的存在,不包含任何字符且长度为0.例如
len()用于计算字符串含有多少字符。例如:
>>>d='abc尚学堂'
>>>len(d)
6
我们可以使用“+特殊字符”,实现某些难以用字符表示的效果。比如:换行等。常见的转义字符有这些:
>>> a = "I\nlove\nyou"
>>> print(a)
I
love
you
>>> b = 'i\'m a teacher'
>>> print(b)
i'm a teacher
字符串拼接
1.可以使用+将多个字符串拼接起来。例如:‘aa’+‘bb’>′aabb’
(1)如果+两边都是字符串,则拼接
(2)如果+两边都是数字,则加法运算。
(3)如果+两边类型不同,则抛出异常
2.可以将多个字面字符串直接放到一起实现拼接。例如:aa’'bb’>abb
字符串复制
使用*可以实现字符串复制
>>>a='Sxt*3
>>>a
Sxtsxtsxt
不换行打
我们前面调用 print时,会自动打印一个换行符。有时,我们不想换行,不想自动添加换行
符。我们可以自己通过参数end=“任意字符串”。实现末尾添加任何内容
print(''sxt'',end='')
print(''sxt'', end='##')
print("sxt'')
sxtsxt##sxt
从控制台读取字符串
我们可以使用 input0从控制台读取键盘输入的内容。
>> myname= input("请输入名字:")
请输入名字:高淇
>> myname
高淇
str()
str()可以帮助我们将其他数据类型转换为字符串。例如
str(5.20)>‘5.20’
str(3.14e2)>'3140′
str(True)==>‘True’
当我们调用 print0函数时,解释器自动调用了str()将非字符串的对象转成了字符串。我们
在面向对象章节中详细讲解这部分内容。
使用[ ]提取字符
字符串的本质就是字符序列,我们可以通过在字符串后面添加[ ],在里面指定偏移量
可以提取该位置的单个字符。
正向搜索:
最左侧第一个字符,偏移量是0,第二个偏移量是1,以此类推。直到len(str)-1
为止
反向搜索
最右侧第一个字符,偏移量是-1,倒数第二个偏移量是-2,以此类推,直到-len(str)
为止
【操作】使用提取字符串中的字符
replace()实现字符串替换
字符串是“不可改变”的,我们通过可以获取字符串指定位置的字符,但是我们不能改变字符串。我们尝试改变字符串中某个字符,发现报错了
字符串不可改变。但是,我们确实有时候需要替换某些字符。这时,只能通过创建新的字符串来实现。
内存图如下:
切片 slice操作可以让我们快速的提取子字符串。标准格式为:
【起始偏移量 start:终止偏移量end:步长step】
典型操作(三个量为正数的情况)如下:
>>> a= 'abcdefghijklmn'
>>>a[2]
'c'
>>>a[1:5]
'bcde'
>>>a[1:5:1]
'bcde'
>>>a[1:5:2]
'bd'
其他操作(三个量为负数)的情况:
切片操作时,起始偏移量和终止偏移量不在[0,字符串长度-1]这个范围,也不会报错
【操作】
1.将” to be or not to be”字符串倒序输出
>>> word = "to be or not to be"
>>> word[::-1]
'eb ot ton ro eb ot'
>>> "to be or not to be"[::-1]
'eb ot ton ro eb ot'
2.将sxtsxtsxtsxtsxt字符串中所有的s输出
>>> 'sxtsxtsxtsxtsxt'[::3]
'sssss'
**split()**可以基于指定分隔符将字符串分隔成多个子字符串(存储到列表中)如果不指定分隔符,则默认使用空白字符(换行符/空格/制表符)。示例代码如下
>> a=''to be or not to be''
>>>a.split()
[to, 'be,'or, 'not, 'to, 'be]
>>>a.split('be')
['to','or not to','']#按照'be'分割
>>> a.split('to')
['', ' be or not ', ' be']#按照to分割
**join()**的作用和 split()作用刚好相反,用于将一系列子字符串连接起来。示例代码如下:
>>> a = ['sxt', 'sxt100','sxt200']
>>> '*'.join(a)
'sxt*sxt100*sxt200'
>>> ''.join(a)
'sxtsxt100sxt200'
拼接字符串要点:
使用字符串拼接符+,会生成新的字符串对象,因此不推荐使用+来拼接字符串。推荐使用join函数,因为join函数在拼接字符串之前会计算所有字符串的长度,然后逐一拷贝,仅新建一次对象。
#导入time包
import time
#测试拼接符+的时间
a = ''
time1 = time.time()#起始时刻
for i in range(1000000):
a += 'sxt'
time2 = time.time()#终止时刻
print("运算时间是:"+str(time2-time1))
#测试join的时间
list = []
time3 = time.time()
for i in range(100000):
list.append('sxt')
a = ''.join(list)
time4 = time.time()
print("运算时间是:"+str(time4-time3))
字符串驻留:
仅保存一份相同且不可变字符串的方法,不同的值被存放在字符串驻留池中。Python支持字符串驻留机制,对于符合标识符规则的字符串(仅包含下划线_、字母和数字)会启用字符串驻留机制驻留机制
例如:下面a和b会共同引用堆内存空间同一个值“abd_33”,但c和d引用不同的对象
is比较内存中的id ,==比较value值
字符串比较和同一性
我们可以直接使用==,=对字符串进行比较,是否含有相同的字符。
我们使用is/ not is,判断两个对象是否同一个对象。比较的是对象的地址,即id(obj1)是否和 id(obj2)相等。
False
>>> a = 'sjdfnacsfvzascxzsc'
>>> 'c' in a
True
>>> 'bed' in a
False
>>> 'bed' not in a
True
我们以一段文本作为测试:
a=’’‘我是高淇今年18岁了我在北京尚学堂科技上班。我的儿子叫高洛希,他6岁了。我是—个编程教育的普及者,希望影响6000万学习编程的中国人。我儿子现在也开始学习编程,希望他18岁的时候可以超过我’’’
>>> len(a)
94
>>> a.startswith('我是高淇')
True
>>> a.find('高')
2
>>> a.rfind('高')
27
>>> a.count('高')
2
>>> a.isalnum()
False
>>>
去除首尾信息
strip()去掉首尾空格
strip(‘’)去掉首尾某字符
lstrip(‘’)去掉首部某字符
rstrip(‘’)去掉尾部某个字符
大小写转换
编程中关于字符串大小写转换的情况,经常遇到。我们将相关方法汇总到这里。为了方便学
习,先设定一个测试变量
a ="gaoqi love programming, love SXT’’
>>> a = "gaoqi love programming, love SXT"
>>> a.capitalize()
'Gaoqi love programming, love sxt'
>>> a.title()
'Gaoqi Love Programming, Love Sxt'
>>> a.upper()
'GAOQI LOVE PROGRAMMING, LOVE SXT'
>>> a.lower()
'gaoqi love programming, love sxt'
>>> a.swapcase()
'GAOQI LOVE PROGRAMMING, LOVE sxt'
格式排版
居中center()、左对齐ljust()、右对齐 rjust()这三个函数用于对字符串实现排版。示例如下:
>>> a = "SXT"
>>> a.center(10,'*')
'***SXT****'
>>> a.center(10)
' SXT '
>>> a.ljust(10,'*')
'SXT*******'
>>> a.rjust(10,'*')
'*******SXT'
>>> a.ljust(10)
'SXT '
>>> a.rjust(10)
' SXT'
其他方法
format0基本用法
基本语法是通过{和:来代替以前的%。
format函数可以接受不限个参数,位置可以不按顺序。
>>> a = ("名字是:{0},年龄是:{1}")
>>> a.format('大仙','18')
'名字是:大仙,年龄是:18'
>>> a = ("名字是:{0},年龄是:{1},{0}是个好小伙")
>>> b = ("名字是:{0},年龄是:{1},{0}是个好小伙")
>>> b.format('大仙','18')
'名字是:大仙,年龄是:18,大仙是个好小伙'
>>> c = ("名字是:{name},年龄是:{age},{name}是个好小伙")
>>> c.format(name = '大仙' , age = 18 )
'名字是:大仙,年龄是:18,大仙是个好小伙
填充与对齐
填充常跟对齐一起使用
、<、>分别是居中、左对齐、右对齐,后面带宽度
:号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充
>>> '{:*^8}'.format('大仙')
'***大仙***'
>>> '我是{0},我喜欢的数字是{1:*>8}'.format('大仙','666')
'我是大仙,我喜欢的数字是*****666'
数字格式化
浮点数通过f,整数通过d进行需要的格式化
>>> a = '我是{0},我的存款是{1:.2f}'
>>> a.format('大仙',5888.88888)
'我是大仙,我的存款是5888.89'