第二天python学习打卡

链式赋值
x=y=123 相当于x=123;y=123
x,y指向同一个地址

系列解包赋值(个数必须一致)
a,b,c=4,5,6 相当于a=4;b=5;c=6

变量互换
a,b=10,20
a,b=b,a

数据类型
type:
每个对象都有类型,python中最基本的内置数据类型:
1.整型
整数,2345,10,50
2.浮点型
小数,3.14 或者科学计数法 314e-2
3.布尔型
表示真假,仅包含:True、False
4.字符串型
由字符组成的序列。”abc” " sxt”,"尚学堂”,”百战程序员”

数字
Python支持整数(如∶50,520)和浮点数(如∶3.14,10.0,1.23e2),我们可以对数字做如下运算。

在这里插入图片描述
在这里插入图片描述

使用divmod0)函数同时得到商和余数:

> > > divmod(13,3)
(4,1)

Python 中,除10进制,还有其他三种进制:
-0b 或0B,二进制o 1
-0o或0O,八进制0 1 2 3 4 5 6 7
-0x或 0X,十六进制0 1 2 3 4 5 6 7 8 9 a b c d e f

【操作】测试不同进制

>>>12
12
>> > 0b10
15
>> > 0o19
SyntaxError: invalid syntax
> > > 0o10
8
> > > 0xff
255
>> > 0xf
15
>> > 0x10
16

使用int实现类型转换∶
1.浮点数直接舍去小数部分。如:int(9.9)结果是:9
2.布尔值True转为1,False转为0。如: int(True)结果是1
3.字符串符合整数格式(浮点数格式不行)则直接转成对应整数,否则报错。
自动转型:
整数和浮点数混合运算时,表达式结果自动转型成浮点数。比如∶2+8.0的结果是10.0

浮点数
浮点数,称为float。
浮点数用a×b^10形式的科学计数法表示。比如:3.14,表示成:314E-2或者314e-2。这些数字在内存中也是按照科学计数法存储。

类型转换和四舍五入
1.类似于int(),我们也可以使用float()将其他类型转化成浮点数。
2.整数和浮点数混合运算时,表达式结果自动转型成浮点数。比如∶2+8.0的结果是10.0
3.round(value)可以返回四舍五入的值
注∶但不会改变原有值,而是产生新的值

增强型赋值运算符
运算符+、-、*,1、1/、**和%和赋值符=结合可以构成“增强型赋值运算符”。
a = a+ 1等价于:a+=1
第二天python学习打卡_第1张图片

时间的表示
计算机中时间的表示是从“1970年1月1日00:00:00”开始,以毫秒(1/1000秒)进行计算。我们也把1970年这个时刻成为“unix时间点”。
这样,我们就把时间全部用数字来表示了。

第二天python学习打卡_第2张图片

python中可以通过time.time()获得当前时刻,返回的值是以秒为单位,带微秒(1/1000毫秒)精度的浮点值。例如:1530167364.8566。

第二天python学习打卡_第3张图片

布尔值
Python2中没有布尔值,直接用数字О表示 False,用数字1表示True。
Python3中,把True和False定义成了关键字,但他们的本质还是1和0,甚至可以和数字相加。

>>> a =True
>>>b = 3
>>> a+b
4

比较运算符
所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。
以下搜设变量a为15,变量b 为 30 :
第二天python学习打卡_第4张图片

逻辑运算符
第二天python学习打卡_第5张图片

>>> b=20
>>> a =10
>>> a<b
True
>>>a !=b
True
>>>a =True
>>>b =False
>>> a or 30
True
>>> b or 30
30
>>>a ==b
False
>>>a or 30/0
True

同一运算符
同一运算符用于比较两个对象的存储单元,实际比较的是对象的地址。

第二天python学习打卡_第6张图片

is==区别:
is 用于判断两个变量引用对象是否为同一个,既比较对象的地址。
==用于判断引用变量引用对象的值是否相等,默认调用对象的__eq__()方法。
>>>a =1000
b =1000
>>>a == b
True
>>>a is b
False
>>>id(a)
46764560
>>>id(b)
4676521d

整数缓存问题
Python仅仅对比较小的整数对象进行缓存(范围为[-5,256])缓存起来,而并非是所有整数对象。需要注意的是,这仅仅是在命令行中执行,而在Pycharm或者保存为文件执行,结果是不一样的,这是因为解释器做了一部分优化(范围是[-5,任意正整数])。
第二天python学习打卡_第7张图片

总结

1is 比较两个对象的id值是否相等,是否指向同一个内存地址;
2==比较的是两个对象的内容是否相等,值是否相等;
3、小整数对象[-5,256]在全局解释器范围内被放入缓存供重复使用;
4is运算符比==效率高,在变量和 None进行比较时,应该使用is

字符串
字符串基本特点
很多人初学编程时,总是担心自己数学不行,潜意识里认为数学好才能编程。实际上,大多数程序员打交道最多的是“字符串”而不是“数字”。因为,编程是用来解决现实问题的,因此逻辑思维的重要性远远超过数学能力。
字符串的本质是︰字符序列。Python的字符串是不可变的,我们无法对原字符串做任何修改。但,可以将字符串的一部分复制到新创建的字符串,达到“看起来修改”的效果。
Python不支持单字符类型,单字符也是作为一个字符串使用的。
字符串的编码
Python3直接支持Unicode,可以表示世界上任何书面语言的字符。Python3的字符默认就是16位Unicode编码,ASCII码是Unicode编码的子集。
使用内置函数ord()可以把字符转换成对应的Unicode码;使用内置函数chr()可以把十进制数字转换成对应的字符。

>>>ord(‘A’)
65
>>>ord(‘高')
39640
>>> chr(66)
'B'
>>> ord(“淇”)
28103

引号创建字符串
我们可以通过单引号或双引号创建字符串。例如∶ a=’ abc’ ; b=”sxt”
使用两种引号的好处是可以创建本身就包含引号的字符串,而不用使用转义字符。例如∶

>>>a = "I'm 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。例如∶
>>> c = "
>>>len(c)
0
len0用于计算字符串含有多少字符。例如∶
>>> d = 'abc尚学堂’
>>>len(d)
6

转义字符
我们可以使用“+特殊字符”,实现某些难以用字符表示的效果。比如︰换行等。常见的转义字符有这些:
第二天python学习打卡_第8张图片

【操作】测试转义字符的使用

>>>a = 'I\nlove\nU"
>>> a
'I\nlove\nU'
>> > print(a)
I
love
U

>>>print ('aaaaaaaa \
ccccdddd')
aaaaaaaaccccdddd


字符串拼接

1.可以使用+将多个字符串拼接起来。例如: ‘ aa’+ ' bb’==>'aabb’.
(1)如果+两边都是字符串,则拼接。
(2)如果+两边都是数字,则加法运算。
(3)如果+两边类型不同,则抛出异常。
2.可以将多个字面字符串直接放到一起实现拼接。例如:’aa’  ' bb’==>' aabb'

【操作】字符串拼接操作

>>>a ='sxt'+'gaoqi"
>>>a
'sxtgaoqi'
>>>b= 'sxt’’gaoqi'
>>> b
'sxtgaoqi'

第二天python学习打卡_第9张图片

字符串复制
使用*可以实现字符串复制。
【操作】字符串复制操作

a = ‘Sxt’*3
a
'SxtSxtSxt’

不换行打印
我们前面调用print时,会自动打印一个换行符。有时,我们不想换行,不想自动添加换行
符。我们可以自己通过参数end =”任意字符串”。实现末尾添加任何内容︰
建立源文件mypy_06.py :
print(“sxt”,end=’’)
print(“sxt”,end= '##’)
print(“sxt”)
运行结果︰
sxt sxt##sxt

从控制台读取字符串
我们可以使用input()从控制台读取键盘输入的内容。

>>> myname = input(“请输入名字:")
请输入名字:高淇
>>>myname
'高淇’
str()实现数字转型字符串
str()可以帮助我们将其他数据类型转换为字符串。例如∶
str(5.20)==>'5.20'
str(3.14e2)==>314.0'
str(True) ==>'True'

当我们调用print()函数时,解释器自动调用了str()将非字符串的对象转成了字符串。我们在面向对象章节中详细讲解这部分内容。

使用[]提取字符
字符串的本质就是字符序列,我们可以通过在字符串后面添加[,在[里面指定偏移量,可以提取该位置的单个字符。
正向搜索︰
最左侧第一个字符,偏移量是0,第二个偏移量是1,以此类推。直到 len(str)-1为止。
反向搜索︰
最右侧第一个字符,偏移量是-1,倒数第二个偏移量是-2,以此类推,直到-len(str)为止。

>>> a = 'abcdefghijklmnopqrstuvwxyz'
'abcdefghijklmnopqrstuvwxyz'
>>> a[0]   
a                 
>>>a[3]               
'd'                   
>>> a[26-1]            
'z'         
>>> a[-1]   
'z'       
>>> a[-26]
'a'

replace()实现字符串替换
字符串是“不可改变”的,我们通过可以获取字符串指定位置的字符,但是我们不能改变字符串。我们尝试改变字符串中某个字符,发现报错了:

>>> a = 'abcdefghijklmnopqrstuvwxyz'
>>>a
'abcdefghijklmnopqrstuvwxyz'
>>> a[3]='高’
Traceback (most recent call last):
File " ", line 1, in <module>
a[3]='高’
TypeError: 'str' object does not support item assignment

字符串不可改变。但是,我们确实有时候需要替换某些字符。这时,只能通过创建新的字符串来实现。

>>> a = ‘abcdefghijklmnopqrstuvwxyz’
>>> a
'abcdefghijklmnopqrstuvwxyz'
>>> a = a.replace(‘c’,’高’)
'ab高defghijklmnopqrstuvwxyz'

在这里插入图片描述

整个过程中,实际上我们是创建了新的字符串对象,并指向了变量a,而不是修改了以前的字符串。内存图如下:

第二天python学习打卡_第10张图片

字符串切片slice操作
切片slice操作可以让我们快速的提取子字符串。标准格式为∶
[起始偏移量start :终止偏移量end :步长step]
左闭右开,步长是隔“设置的步长数-1”个去取,。步长是1,则不隔,2则隔一个取一个。以此类推
典型操作(三个量为正数的情况)如下︰
第二天python学习打卡_第11张图片

左闭右开,步长是隔“设置的步长数-1”个去取,。步长是1,则不隔,步长2则隔一个取一个。以此类推

其他操作(三个量为负数)的情况∶
第二天python学习打卡_第12张图片

切片操作时,起始偏移量和终止偏移量不在[0,字符串长度-1]这个范围,也不会报错。起始偏移量小于0则会当做0,终止偏移量大于“长度-1”会被当成-1。例如∶

>>> "abcdefg"[3:50]
'defg'

【操作】
1.将”to be or not to be”字符串倒序输出
2.将”sxtsxtsxtsxtsxt”字符串中所有的s输出
第二天python学习打卡_第13张图片

split()分割和join()合并
split()可以基于指定分隔符将字符串分隔成多个子字符串(存储到列表中)。如果不指定分隔符,则默认使用空白字符(换行符/空格/制表符)。示例代码如下:

>>> a = "to be or not to be"
>>> a.split()
['to', 'be', 'or", 'not', 'to' , 'be']
>>> a.split('be')
['to ', ' or not to ', "]

join()的作用和split()作用刚好相反,用于将一系列子字符串连接起来。示例代码如下∶

>>> a = ['sxt’ ,'sxt100’ ,’sxt200’]
>>>'*.join(a)
'sxt*sxt100*sxt200'

拼接字符串要点∶
使用字符串拼接符+,会生成新的字符串对象,因此不推荐使用+来拼接字符串。推荐使用join 函数,因为join 函数在拼接字符串之前会计算所有字符串的长度,然后逐一拷贝,仅新建一次对象。
【操作】测试+拼接符和join(),不同的效率

字符串驻留机制和字符串比较
字符串驻留∶仅保存一份相同且不可变字符串的方法,不同的值被存放在字符串驻留池中。
Python支持字符串驻留机制,对于符合标识符规则的字符串(仅包含下划线( _ )、字母和数字)会启用字符串驻留机制驻留机制。

>>> a = "abd_33"
>>> b = "abd_33"
>>> a is b
True
>>>c = "dd#"
>>> d = "dd#"
>>> c is d
False
>>> str1 = "aa"
>>> str2 = "bb"
>>> str1+str2 is "aabb"
False
>>> str1+str2 == "aabb"
True

字符串比较和同一性
我们可以直接使用==,!=对字符串进行比较,是否含有相同的字符。
我们使用is / not is,判断两个对象是否同一个对象。比较的是对象的地址,即 id(obj1)是
否和id(obj2)相等。

成员操作符
in /not in关键字,判断某个字符(子字符串)是否存在于字符串中。
第二天python学习打卡_第14张图片

字符串常用方法汇总
字符串有很多常用的方法,我们需要熟悉。我们通过表格将这些方法汇总起来,方便大家查阅。希望大家针对每个方法都做一次测试。

常用查找方法
我们以一段文本作为测试︰
a=’’’我是高淇,今年18岁了,我在北京尚学堂科技上班。我的儿子叫高洛希,他6岁了。我是一个编程教育的普及者,希望影响6000万学习编程的中国人。我儿子现在也开始学习编程,希望他18岁的时候可以超过我’’’
第二天python学习打卡_第15张图片

去除首尾信息
我们可以通过strip()去除字符串首尾指定信息。通过lstrip()去除字符串左边指定信息,rstrip()去除字符串右边指定信息。
【操作】去除字符串首尾信息

>>>"*s*x*t*".strip("*")
's*×*t'
>>>"*s*x*t*”.Istrip("*")
‘s*×*t*>>>*s*x*t*".rstrip("*")*s*x*t'
>>>”    sxt".strip()
'sxt'

大小写转换
编程中关于字符串大小写转换的情况,经常遇到。我们将相关方法汇总到这里。为了方便学习,先设定一个测试变量︰
a = “gaoqi love programming, love SXT”

第二天python学习打卡_第16张图片

格式排版
居中―左对齐右对齐
center()、ljust()、rjust()这三个函数用于对字符串实现排版。示例如下︰

>>> a="SXT"
>>> a.center(10,"*")
'***SXT***>>> a.center(10)
‘   SXT  ‘
>>> a.ljust(10,"*")
'SXT******

其他方法
1.isalnum() 是否为字母或数字
2.isalpha() 检测字符串是否只由字母组成(含汉字)。
3. isdigit() 检测字符串是否只由数字组成。
4. isspace() 检测是否为空白符
5. isupper() 是否为大写字母
6. islower() 是否为小写字母

第二天python学习打卡_第17张图片

字符串的格式化
format()基本用法
Python2.6开始,新增了一种格式化字符串的函数 str.format(),它增强了字符串格式化的功能。
基本语法是通过{}和:来代替以前的%。
format函数可以接受不限个参数,位置可以不按顺序。

我们通过示例进行格式化的学习。

>>>a ="名字是:{0},年龄是:{1}"
>>>a.format("高淇",18)
'名字是:高淇,年龄是: 18'
>>> a.format("高希希",6)
'名字是:高希希,年龄是:6'
>>>b ="名字是:{0},年龄是{1}。{0}是个好小伙"
>>> b.format("高淇",18)
‘名字是:高淇,年龄是18。高淇是个好小伙'
>>>c ="名字是{name},年龄是{age}"
>>> c.format(age=19,name='高淇')
‘名字是高淇,年龄是19'

我们可以通过{索引}/{参数名},直接映射参数值,实现对字符串的格式化,非常方便

填充与对齐

填充常跟对齐一起使用
^、<、>分别是居中、左对齐、右对齐,后面带宽度
:号后面带填充的字符,只能是一个字符,不指定的话默认是用空格填充

>>>"{:*>8] ".format("245")
'*****245'
>>>"我是{0},我喜欢数字{1:*^个8}".format("高淇", "666")
'我是高淇,我喜欢数字**666***'

数字格式化
浮点数通过f,整数通过d进行需要的格式化。案例如下:

>>>a ="我是{0},我的存款有{1:.2f}"
>>>a.format("高洪"",3888.234342)
‘我是高洪,我的存款有3888.23'

其他格式

第二天python学习打卡_第18张图片

你可能感兴趣的:(python,学习,开发语言)