None类型

Python3中没有NULL,取而代之的是空类型None、空列表、空字典等。
None是一个特殊的Python对象,表示
None的类型是NoneType。

如果只想声明变量,而不想赋值,可以这么做:

a=None     #声明一个变量

通过type()函数可以查看变量的类型:

a=None
print(type(a))  #输出<class 'NoneType'>

数字类型

Python3中有以下数字类型:

  • int #整数
  • float #浮点数
  • bool #布尔类型
  • complex #复数

小贴士:

Python2中还有long类型。
到了Python3中,整数都变成了int。

int整数

示例:

a=1     #定义一个int型变量

强制转换:

print(float(2))     #将int转换成float (结果为2.0)
print(chr(65))      #将一个整数转换为一个字符 (结果为A)
print(ord('a'))     #将一个字符转换为它的整数值 (结果为97)
print(hex(15))      #将一个整数转换为一个十六进制字符串 (结果为0xf)
print(oct(10))      #将一个整数转换为一个八进制字符串 (结果为0o12)

float浮点数

示例:

a=2.4       #定义一个float变量

强制转换:

int(2.4)   #将浮点数强制转换成int,会将小数部分剔除 (结果为2)

bool布尔类型

bool类型只有两个值:True和False。

示例:

b=True
b= 1>3 and 4>0  #逻辑语句(结果为False)

在Python中,0、None、空列表、空字典等为False,其他都为真。

但None和空列表等比较特殊:

a=None and True     #结果为None
b=None and False    #结果为None
c=[] and True       #结果为[]
d=[] and False      #结果为[]

a=None or True     #结果为True
b=None or False    #结果为False
c=[] or True       #结果为True
d=[] or False      #结果为False

print(not [])      #结果为True
print(not None)    #结果为True

complex

complex由实数和虚数组合构成,分别表示为:x+yj。
其中,x和y都是浮点数。

示例:

a=1+2.3j        #定义一个复数
a=complex(2,3)  #定义一个复数

complex可以进行算术运算:

a=1+2j
b=2+3j
print(a+b)

complex的属性与函数:

a=1+2.3j
print(a.real)   #返回实部 (结果为1.0)
print(a.imag)   #返回虚部 (结果为2.3)
print(a.conjugate())    #返回共轭复数 (结果为1-2.3j)

List列表

什么是列表

  • List类似C语言中的数组,但List能提供更为强大的功能,如增删改查、排序、切片等
  • 列表中的元素可以是不同的数据类型。
  • 下标从0开始

示例:

a=[11,22,33,44]     #定义一个列表
a=['张三',18,"男"]  #列表中的元素可以不同数据类型

访问元素:

a=[11,22,33,44]
print(a[0])     #访问下标为0的元素,输出11

List嵌套

List中可以是不同数据类型:

a=[1,2,'abc']

既然说列表中的元素可以是不同数据类型,那么元素也可以是List:

a=[11,22,[1,2,3,4],44]
print(a[2])     #输出[1, 2, 3, 4]
print( a[2][1] )#输出2

解释:

  • a[2]得到的元素也是一个列表[1,2,3,4]
  • a[2][1]表示得到列表中的列表中的元素2,将a[2]看作一个整体
  • a[2][1]形式与C/C++等语言中的二位数组类似。

增-往列表中添加数据

  • 追加、插入
a=[11,22,33,44]
a.append('abc')     #在最后追加元素'abc'
a.insert(2,'qwe')   #在下标2处添加元素'qwe',原先2以后的元素依次后移
print(a)            #输出[11, 22, 'qwe', 33, 44, 'abc']
  • 合并列表
a=[11,22,33,44]
b=['aa','bb']
c = a+b       #列表合并后赋值给c (a和b本身无变化)
print(c)      #输出[11, 22, 33, 44, 'aa', 'bb']
a=[11,22,33,44]
b=['aa','bb']
a.extend(b) #将列表b插入到a的后面
print(a)    #输出[11, 22, 33, 44, 'aa', 'bb']

删-删除列表中的元素

  • remove()
a=['aaa','bbb','ccc','bbb']
a.remove('bbb')     #删除第一个'bbb',a变成['aaa', 'ccc', 'bbb']
a.remove(a[2])      #删除下标为2的元素

通过a.remove('bbb')可以知道remove函数是通过元素值来删除的。

a.remove(a[2])适用于元素不重复的列表,不然可能删除的不是下标为2的元素,而是在这之前的、与a[2]内容相同的元素。

  • pop()
a=['aaa','bbb','ccc','bbb']
a.pop(2)    #删除下标为2的元素,返回删除的值
a.pop()     #删除最后的元素,返回删除的值
  • del
a=['aaa','bbb','ccc','bbb']
del a[2]    #删除下标为2的元素
del a       #删除此列表
  • clear()清空列表
a.clear()   #清空列表
  • 进阶:通过append()和pop()实现栈的功能

append()追加,用于入栈
pop()弹出,用于出栈

a=[]
a.append(1)     #入栈 (a=[1])
a.append(2)     #入栈 (a=[1,2])
i=a.pop()       #出栈 (a=[1],i=2)

查-查询列表中的元素

  • 通过下标可以直接查询
a=['aaa','bbb','ccc','bbb']
print(a[1])     #输出bbb
  • 通过运算符 in 可以查询是否存在某元素
a=['aaa','bbb','ccc','bbb']
if "ccc" in a:
    print("a中存在元素'ccc'")

解释:

“ccc” in a 将返回bool值

若a中存在元素"ccc",则返回True,否则返回False

与运算符in对应的是not in

切片

通过切片可以截取列表中的片段

切片语法:

a = ['aaa','bbb','ccc','ddd']
b = a[0:2]    #截取下标0~1的元素,产生新列表赋值给b
b = a[1:]     #截取下标1到最后一个元素

结果:

['aaa', 'bbb']
['bbb', 'ccc', 'ddd']

解释:

b = a[0:2]中的0表示切片起始下标(包括下标0)

b = a[0:2]中的2表示切片结束下标(不包括下标2)

如果省略结束下标,即一直切片到最后一个元素



切片-步长

示例:

a = ['aaa','bbb','ccc','ddd','eee','fff','ggg']
b = a[0:5:2]    #结果为['aaa', 'ccc', 'eee']

解释:

b = a[0:5:2]中的2表示步长
步长为2时,切片就会间隔2个元素进行截取元素。
上例将bbb、ddd、fff丢弃,切片到fff结束



  • 当步长为负数时,表示从右往左切片。
a = ['aaa','bbb','ccc','ddd']
b = a[-1:-3:-1]     #结果为['ddd', 'ccc']

解释:

最后的-1表示步长
当步长为负数时,表示从右往左切片
-1代表倒数第一个字符
-3代表倒数第三个字符
默认步长为1,表示从左到右无间隔切片

改-修改列表中的元素

通过下标修改:

a = ['aaa','bbb','ccc','ddd']
a[1]='111'     #将'bbb'修改为'111'
print(a)       #结果为['aaa', '111', 'ccc', 'ddd']

通过切片修改:

a = ['aaa','bbb','ccc','ddd']
a[1:3]=['111','222']    #将下标1~2修改为'111','222'
print(a)       #结果为['aaa', '111', '222', 'ddd']

列表-排序

a = ['aaa','bbb','ccc','ddd']
a.sort()                #从小到大排序(会改变自身)
a.sort(reverse=True)    #从大到小排序
b=sorted(a)             #将a排序后返回给b,a不发生变化
a.reverse()             #反转

列表-内置函数

a = ['aaa','bbb','aaa','bbb']
print( a.index('bbb') )   #查找元素bbb的下标(若有多个,只返回第一个)(此结果为1)
print( a.count('bbb') )   #返回元素222的数量 (结果为2)
print( len(a) )           #返回列表元素个数 (结果为4)

遍历列表

在Python中,只要为序列,就可以被遍历,List自然不例外

示例:

a = ['aa','bb','cc','dd']
for i in a:
    print(i)

结果:

aa
bb
cc
dd

列表生成式

利用列表生成式,可按照表达式生成列表

示例:

a=[x*x for x in range(100)]print(a)

结果:

[0, 1, 4, 9, 16, …… , 9604, 9801]

解释:

  • x的值依次为0~99
  • x*x为表达式,所以列表中的值依次为02,12,22,32,……,992
for+if
a=[x*x for x in range(100) if x%2==0]
print(a)

结果:

[0, 4, 16, 36, …… , 9216, 9604]

解释:

  • 由于if语句的过滤,x的值依次为0,2,4,6,…… ,96,98
  • x*x为表达式,所以列表中的值依次为02,22,42,62,……,982
  • 除此之外,还有for+for等语句
for+函数
def func1(x):
    return x*x
a=[func1(x) for x in range(100)]
print(a)

元组Tuple

元组和List类似,拥有很多一样的属性和方法。
唯一的区别是:元组内的元素不可被修改。

示例:

a = ('aaa','bbb','ccc','ddd')
print(a[2])     #输出ccc

字典Dictionary

什么是字典

字典有以下特征:

  • Python中唯一的映射类型
  • 由键和值构成
  • 通过键存取元素,所以键唯一
  • 无序存储,会被哈希
  • 键必须是不可变类型
  • 可变类型 :列表,字典等
  • 不可变类型:整型,浮点型,布尔型,元组等

举例:

dic1={'name':'flight','age':20,'sex':'male'}        #定义一个字典

一个键对应一个值:




增加和修改元素

在字典中,键相当于List中的下标,通过键就可以对值进行存取

例如:

dic1['age']=20      #通过下标修改或增加键值对
  • 当字典中不存在此键时,就添加此键值对。

示例:

dic1={'name':'张三','age':18,'sex':'男'}
print( dic1['name'] )       #输出:张三
dic1['age']=20              #将age修改为20
dic1['favorable']='计算机'  #添加键值对'favorable':'计算机'
查询元素

在字典中,键相当于List中的下标,通过键就可以对值进行存取

同样的道理,通过键来取出想要的键值对。

示例:

dic1={'name':'张三','age':18,'sex':'男'}
dic1['name']       #取值(不存在则报错)
dic1.get('name')   #取值(不存在不报错)

通过in、not in查询:

dic1={'name':'张三','age':18,'sex':'男'}
if 'name' in dic1:      #dic1中存在此键则为True
    print("dic1中有'name'键")
删除元素
dic1={'name':'张三','age':18,'sex':'男'}
del dic1['name']        #删除键为'name'的键值对
del dic1                #删除整个字典
dic1.clear()            #清空字典
myName=dic1.pop('name') #删除键为'name'的键值对,并返回'name'的值
kv=dic1.popitem()       #删除最后添加到字典中的键值对,并返回此键值对
排序
  • 字典的键是无序的。
  • sorted函数可以得到一个根据键排序后的列表,再根据此列表进一步得到相应的值。

示例:

dic1={'name':'张三','age':18,'sex':'男'}
list1 = sorted(dic1)    #得到['age', 'name', 'sex']
for i in list1:
    print(dic1[i])

结果:

18
张三
男
字典中的内置函数
  • setdefault()函数
dic1={'name':'张三','age':20,'sex':'男'}
a=dic1.setdefault('age',18)     #如果存在此键,不作任何变动;如果不存在,增加此键值对
			        #还返回age此时的值
  • keys()、values()、items()
dic1={'name':'张三','age':20,'sex':'男'}
list(dic1.keys())     #得到所有的键,list做强制转换
list(dic1.values())   #得到所有的值,list做强制转换
list(dic1.items())    #得到所有的键值对,list做强制转换
  • update()
dic1={'name':'张三','age':20}
dic_temp={'name':'李四','birthday':'1998-01-01'}
dic1.update(dic_temp)  #将dic_temp加入到dic中,键重复则覆盖
print(dic1)     #结果为{'name': '李四', 'age': 20, 'birthday': '1998-01-01'}
  • fromkeys()
dic1=dict.fromkeys(['host1','host2','host3'],'test')   #创建并初始化字典
print(dic1)

结果:

{'host1': 'test', 'host2': 'test', 'host3': 'test'}

解释:

fromkeys()函数用于创建并初始化字典
参数1:key
参数2:value
每一个键对应的值都为’test’


集合-Set

什么是集合
  • 集合(set)是一个无序的、不重复元素序列。
  • 集合中的元素可以是不同数据类型。
  • 可以使用大括号 { } 或者 set() 函数创建集合
  • 注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

创建一个集合:

s1=set()        #创建一个空集合
s2={1,2,3,1,2}  #会被去掉重复项,变成{1, 2, 3}
s=set('Hello') #s={'H','e','l','o'}

强制转换:

list1=[1,2,3,1,2]s1=set(list1)       #将List转换成set,去除重复项list1=list(s1)      #将Set转换成List,变成[1, 2, 3]

List和Set可以互相转换

s={1,2,3}
s.add('uu')        #增加一个元素
s.update('pos')    #增加'p', 'o', 's'三个元素
s.update('a','b')  #增加'a','b'两个元素(update函数可以传入多个参数)
s={1,2,3}
s.remove('o')  #移除元素'o'
chr=s.pop()    #随机弹出一个值,并返回这个值
s.clear()      #清空集合
s={1,2,3}
if 1 in s:     #查询s中是否含有元素 1
    print("s中含有元素1")
集合运算
a < b     #判断a是否属于b,相当于a.issubset(b)
a > b    #判断b是否属于a,相当于a.issuperset(b)
a == b    #判断a和b是否相等

还有>=、<=负号

a & b   #交集,相当于a.intersection(b)
a | b  #并集,相当于a.union(b)
a - b  #差集,相当于a.difference(b)
a ^ b  #对称差集(去除交集后的并集),相当于a.symmetric_difference(b)

示例:

a={1,2}
b={1,2,3}
print(a<b) #判断a是否属于b

字符串-String

关于String

在Python中,单引号和双引号的作用是一样的

s1='eagle'
s2="eagle"

多行字符串:

msg='''
    hello1
    hello2
    hello3
'''

字符串中带有单引号和双引号:

print("it's mother's apple")    #输出单引号
print('"I love you"said Tom')   #输出双引号
print(''' aaa""bbb''ccc''')     #输出单双引号
字符串运算
  • 切片:同样可以像List一样切片
s1='eagle'
s2=s1[1:3]      #s2='ag'
print(s2)
  • 通过下标[]获取字符
s="hello"
print(s[1])     #输出e
  • 乘法与加法
"123qwe"*2          #结果为'123qwe123qwe'
c='123'+'abc'     #效率比较低,可以使用join方法(结果为'123abc')
  • in和not in运算符
if 'el' in 'hello':    #判断'el'是否存在于'hello'中
    print('''  "hello"中含有字串'el'  ''')
转义符

示例:

s="hello\nworld"    #\n被转义成换行
print(s)

结果:

hello
world
  • 取消转义
s=r"hello\nworld"    #字符串前加 r,表示取消转义
print(s)       #结果为hello\nworld

转义符:

转义字符

描述

\(在行尾时)

续行符

\\

反斜杠符号

\’

单引号

\"

双引号

\a

响铃

\b

退格(Backspace)

\000


\n

换行

\v

纵向制表符

\t

横向制表符

\r

回车

\f

换页

\oyy

八进制数,yy 代表的字符,例如:\o12 代表换行,其中 o 是字母,不是数字 0。

\xyy

十六进制数,yy代表的字符,例如:\x0a代表换行

\other

其它的字符以普通格式输出

强制转换
  • Python中,万物皆可转化为字符串。

示例:

str([1,2,3])
str({"name":"张三","age":18})
字符串中的内置函数
s='+'.join(['a','b'])   #使用'+'连接'a'和'b' (结果为'a+b')
s=''.join(['a','b'])    #连接列表中的元素 (结果为'ab')
s='+'.join('abc')       #使用'+'夹在'abc'各字母的中间 (结果为'a+b+c')
s='hello my home'.split(' ')   #使用' '分割字符串,返回一个列表 (结果为['hello', 'my', 'home'])
c='hello'.count('l')       #计算字母的个数 (结果为2)
s='hello'.capitalize()     #将首字母大写 (结果为'Hello')
s='hello'.center(10,'-')   #字符串居中,'-'填充,总占用10个位置 (结果为'--hello---')
b='hello'.startswith('he') #查看字符串是否以he开头,返回布尔值 (结果为True)
b='hello'.endswith('lo')   #查看字符串是否以lo结尾,返回布尔值 (结果为True)
c='hello'.find('ll')       #查找'll'的下标 (结果为2)
c='hello'.index('ll')      #查找'll'的下标,如果不存在则报错 (结果为2)
s='hello {name}'.format(name='flight') #将{name}置换成'flight'返回 (结果为hello flight)
s='hello {name}'.format_map({'name':'flight'}) #参数为字典 (结果为hello flight)
b='123'.isdigit()          #查看字符串是否为整型数字,返回bool值 (结果为True)
b='2flight'.isidentifier() #查看字符串是否符合命名规则 (结果为False)
b='aBc'.islower()      #查看字符串是否全小写 (结果为False)
b='aBc'.isupper()      #查看字符串是否全大写 (结果为False)
b='   \t'.isspace()    #查看字符串是否全为空白字符 (结果为True)
s='My'.lower() #所有大写字母变小写 (结果为'my')
s='My'.upper() #所有小写字母百年大写 (结果为'MY')
s='My'.swapcase()      #大写变小写,小写变大写 (结果为'mY')
b='My Home'.istitle()  #查看字符串是否为标题格式(所有单词首字母大写)(结果为True)
s='Hello eagle'.title()    #将字符串变成title格式 (结果为'Hello Eagle')
s=' hello \n'.strip()  #将字符串开头和结尾的空格、换行符和制表符去除 (结果为'hello')
s='hello'.replace('he','123')  #将'he'替换成'123' (结果为'123llo')

bytes类型

  • bytes是Python3中新增的数据类型,是以字节为单位存储的序列。
    bytes是一种特殊的字符串。
    String拥有的内置函数,一般bytes也拥有
    由于bytes使用字节存储,可作为字节流写入文件发送网络报文
a=b'123'            #这是bytes,而不是字符串
print(type(a))      #输出<class 'bytes'>

解释:

  • 上例中,在字符串前加b用于标明,这是bytes,而不是str
str与bytes互相转换
s1="你好"
b=bytes(s1,"UTF-8")   #UTF-8编码的字符串 -> bytes
b=s1.encode("utf8")   #UTF-8编码的字符串 -> bytes
print(b)    #输出:b'\xe4\xbd\xa0\xe5\xa5\xbd'

s2=str(b,"UTF-8")     #bytes -> UTF-8编码的字符串
s2=b.decode("utf8")   #bytes -> UTF-8编码的字符串
print(s2)   #输出:你好

解释:

从 \xe4\xbd\xa0\xe5\xa5\xbd 可以看出,一个中文占3个字节


深浅拷贝

浅拷贝
a=[[1,2],3,4]b=a.copy() #浅拷贝,只拷贝第一层

解释:

  • 当b[0]中的元素改变之后,a的值也会变化。如b[0][1]=100。
    原因是a中第0个元素使用地址保存,同样的地址被赋值给b。a[0]和b[0]指向同一块内存。
深拷贝
import copy         #引入模块
a=[[1,2],3,4]
b=copy.deepcopy(a)  #深拷贝
下例情况不是拷贝
a=[[1,2],3,4]
b=a

解释:

  • a直接赋值给b,那b和a就指向同一块内存,不存在拷贝列表中元素这一说。