基本数据类型及内置方法 1.int类型和float类型 2.字符串类型(str) 3、列表类型 4、元组 5、字典 6. 集合

定义:

age = 10 # age=int(10)
salary=3.1 # salary=float(3.1)

类型转换

  • 纯数字的字符串转成int
res=int('100111')
print(res,type(res))
# 100111 <class 'int'>

res=float("3.1")
print(res,type(res))
#3.1 <class 'float'>

进制转化

  • 二进制:bin()
  • 八进制:oct()
  • 十六进制:hen()
#其他制转成其十进制
# 二进制->10进制
# print(int('0b1011',2)) # 11

# 二进制->8进制
# print(int('0o13',8)) # 11

# 二进制->16进制
# print(int('0xb',16)) # 11

2.字符串类型(str)

定义

# 定义:在单引号双引号三引号内包含一串字符
name1 = 'jason'  # 本质:name = str('任意形式内容')
name2 = "lili"  # 本质:name = str("任意形式内容")
name3 = """ricky"""  # 本质:name = str("""任意形式内容""")

类型转换

  • str可以把任意其他类型都转成字符串
res=str({'a':1})
print(res,type(res))
#{'a': 1} <class 'str'>

2.1内置方法

1.按索引取值

正向取值

msg = 'hello world'
print(msg[0])#h
print(msg[6])#w

反向取值

msg = 'hello world'
print(msg[-1])#d

只能取,不能改

msg[0] = 'H'    #会提示报错

2.切片:索引的拓展应用,从一个大字符串中拷贝出一个子字符串

顾头不顾尾

msg='hello world'
res=msg[1:7] #从下标1(也就是第2个字符)开始取,取到下标7-1(第7个字符),空格占1个字符串
print(res)# ello w

步长

msg='hello world'
res=msg[0:5:2] # 从下标0(也就是第1个字符)开始取,取到下标6-1(第5个字符),步长为2
print(res) # hlo

反向步长

msg='hello world'
res=msg[5:0:-1] # 从下标5(也就是第6个字符)开始取,取到下标0(第1个字符),步长为-1
print(res)# olle

正常取值

msg='hello world'
res=msg[:] # 相当于res=msg[0:11]
print(res)

hello world

反向取值

msg='hello world'
res=msg[::-1] # 把字符串倒过来
print(res)

dlrow olleh

3.长度len

msg='hello world'
res = len(msg)  # len用于计算字符串的长度,输出的类型为str
print(msg,type(msg))

hello world <class 'str'>

4.成员运算in和not in

判断一个子字符串是否存在于一个大字符串中

print("alex" in "alex is sb")
True
print("alex" not in "alex is sb")
False
print(not "alex" in "alex is sb") # 不推荐使用
False

5.移除字符串左右两侧的符号strip

默认去掉的是空格

msg='      egon      '
res=msg.strip()
print(msg) # 不会改变原值
print(res) # 是产生了新值

      egon      
egon

可以去掉指定的字符

msg='****egon****'
print(msg.strip('*'))
egon
msg='**/*=-**egon**-=()**'
print(msg.strip('*/-=()'))
egon

strip只去两边,不去中间

msg='****e*****gon****'
print(msg.strip('*'))
#e*****gon

inp_user=input('your name>>: ').strip() # inp_user=" egon"
inp_pwd=input('your password>>: ').strip()
if inp_user == 'egon' and inp_pwd == '123':
    print('登录成功')
else:
    print('账号密码错误')

6.切分split:把一个字符串按照某种分隔符进行切分,得到一个列表

默认分隔符是空格

info='egon 18 male'
res=info.split()
print(res)

['egon', '18', 'male']

可以指定分隔符

info='egon:18:male'
res=info.split(':')
print(res)

['egon', '18', 'male']

可以指定分隔次数(了解)

info='egon:18:male'
res=info.split(':',0)   # 分隔次数为0,就是不分隔
print(res)

['egon:18:male']
info='egon:18:male'
res=info.split(':',1)
print(res)

['egon', '18:male']

7.循环

info='egon:18:male'
for x in info:
    print(x)

8.strip、lstrip、rstrip

strip:移除字符串中指定的符号
lstrip:移除字符串左侧指定的符号
**rstrip:移除字符串右侧指定的符号 **

msg='***egon****'
print(msg.strip('*'))   # 可以移除字符串中指定的符号

9.lower、upper

lower:把字符串中所有字母变成小写字母
upper:把字符串中所有字母变成大写字母

msg='AbbbCCCC'
print(msg.lower()) # abbbcccc
msg='AbbbCCCC'
print(msg.upper())#  ABBBCCCC

10.startswith、endswith

startswith:用于判断一段字符串是否以某段字符或者某个字符串开头
endswith:用于判断一段字符串是否以某段字符或者某个字符串结尾

print("alex is sb".startswith("alex"))# True
print("alex is sb".endswith('sb')) # True

11.format:格式化输出

其实就是format()后面的内容,填入大括号中(可以按位置,或者按变量)

res='我的名字是 {} 我的年龄是 {}'.format('egon',18)
print(res)

我的名字是 egon 我的年龄是 18

12.split、rsplit:将字符串切成列表

split:从左往右切分
rsplit:从右往左切分

info="egon:18:male"
print(info.split(':',1)) # ['egon', '18:male']
print(info.rsplit(':',1)) # ["egon:18","male"]

13.join: 把列表拼接成字符串

按照某个分隔符号,把元素全为字符串的列表拼接成一个大字符串

l=['egon', '18', 'male']
res=l[0]+":"+l[1]+":"+l[2]
res=":".join(l) 
print(res)

egon:18:male

14.replace:替换

msg="you can you up no can no bb"
print(msg.replace("you","YOU",))

YOU can YOU up no can no bb

可以自定义要替换几个

msg="you can you up no can no bb"
print(msg.replace("you","YOU",1))

YOU can you up no can no bb

15.isdigit:判断字符串是否由纯数字组成

print('123'.isdigit())#True
print('12.3'.isdigit())#False

16.find、rfind、index、rindex、count

find:找到返回起始索引

msg='hello egon hahaha'
print(msg.find('e')) # 1  返回要查找的字符串在大字符串中的起始索引
print(msg.find('egon'))# 6

index 查找索引,没有找到抛出异常

print(msg.index('xxx')) # 抛出异常
ValueError: substring not found

count:计算字符串在大字符串中出现的次数

msg='hello egon hahaha egon、 egon'
print(msg.count('egon')) # 3

17.center、ljust、rjust、zfill

center:在center内容中间添加内容
ljust:在ljust内容左边添加内容
rjust:在ljust内容右边添加内容
zfill:在zfill内容中加到指定个数

print('egon'.center(50,'*'))
print('egon'.ljust(50,'*'))
print('egon'.rjust(50,'*'))
***********************egon***********************
egon**********************************************
**********************************************egon
print('egon'.zfill(10))
#000000egon

18.expandtabs

设置制表符代表的空格数

msg='hello	world'
print(msg.expandtabs(2)) # 设置制表符代表的空格数为2

#hello world

19.captalize、swapcase、title

captalize:一段字符串的首个字母大写,其余小写

print("hello world egon".capitalize())

Hello world egon

swapcase:一段字符串的首个字母小写,其余大写

print("Hello WorLd EGon".swapcase())

hELLO wORlD egON

title:每个单词的首字母大写,其余小写

print("hello world egon".title())

Hello World Egon

20.is系列

.isdigit():判断是否全部都是纯数字类型
.islower():判断是否全部都是小写字母
.isupper():判断是否全部都是大写字母
.istitle():判断是否是单词首个字母大写
.isalnum():判断是否由数字或字母组成
.isalpha():判断是否全部由字母构成
.isspace():判断是否全部由空格构成
.isidentifier():判断是否可以定义为变量名

print('123'.isdigit())#True
print('abc'.islower())#True
print('ABC'.isupper())#True
print('Hello World'.istitle())#True
print('123123aadsf'.isalnum()) # 字符串由字母或数字组成结果为True
print('ad'.isalpha()) # 字符串由由字母组成结果为True
print('     '.isspace()) # 字符串由空格组成结果为True
print('print'.isidentifier())#True
print('age_of_egon'.isidentifier())#True
print('1age_of_egon'.isidentifier())#False   # 变量名不能以数字开头

21.数字系列的识别

先定义表示同一个数字的4个不同方法:

num1=b'4' #bytes
num2=u'4' #unicode,python3中无需加u就是unicode
num3='四' #中文数字
num4='Ⅳ' #罗马数字

isdigit只能识别:num1、num2

print(num1.isdigit()) # True
print(num2.isdigit()) # True
print(num3.isdigit()) # False
print(num4.isdigit()) # False

isnumberic可以识别:num2、num3、num4

print(num2.isnumeric()) # True
print(num3.isnumeric()) # True
print(num4.isnumeric()) # True

isdecimal只能识别:num2

print(num2.isdecimal()) # True
print(num3.isdecimal()) # False
print(num4.isdecimal()) # False

3、列表类型

作用

​ 按存储位置催多个值

定义

# l=[1,1.2,'a'] 
# l=list([1,1.2,'a'])

类型转换

res=list('hello')
print(res)

res=list({'k1':111,'k2':222,'k3':3333})
print(res)

3.1 内置方法

1.按索引存取值:既能存也能改

l=[111,'egon','hello']
#正向取
print(l[0])
#反向取
print(l[-1])
#可以取也可以改:索引存在则修改对应的值
l[0]=222
print(l)
#无论是取值操作还是赋值操作:索引不存在则报错

2.切片(顾头不顾尾,步长)

l = [111, 'egon', 'hello', 'a', 'b', 'c', 'd', [1, 2, 3]]

print(l[0:3])

print(l[0:5:2]) # 0 2 4

3.长度

print(len([1, 2, 3]))

4.成员运算in和not in

print('aaa' in ['aaa', 1, 2])
print(1 in ['aaa', 1, 2])

5.往列表中添加值

  • 追加
# l=[111,'egon','hello']
# l.append(3333)
# l.append(4444)
# print(l)
  • 插入值
# l=[111,'egon','hello']
# l.insert(0,'alex')
# print(l)

  • extend添加值
5.3、extend添加值
# new_l=[1,2,3]
# l=[111,'egon','hello']
# l.append(new_l)
# print(l)
# 代码实现
# for item in new_l:
#     l.append(item)
# print(l)

# extend实现了上述代码
# l.extend(new_l)
# l.extend('abc')
# print(l)

6 .删除

  • 方式一:通用的删除方法,只是单纯的删除、没有返回值
# l = [111, 'egon', 'hello']
# del l[1]
# x =del l[1] # 抛出异常,不支持赋值语法
# print(l)
  • 方式二:l.pop()根据索引删除,会返回删除的值
# l = [111, 'egon', 'hello']
# l.pop() # 不指定索引默认删除最后一个
# l.pop()
# print(l)
# res=l.pop(1)
# print(l)

# print(res)
  • 方式三:l.remove()根据元素删除,返回None
# l = [111, 'egon', [1,2,3],'hello']
# l.remove([1,2,3])
# print(l)
# res=l.remove('egon')
# print(res) # None

7.循环

# l=[1,'aaa','bbb']
# for x in l:
#     l.pop(1)
#     print(x)

8 .count():记录出现次数

l = [1, 'aaa', 'bbb','aaa','aaa']
# print(l.count('aaa'))

9 .index():记录查询到值的第一个索引

l = [1, 'aaa', 'bbb','aaa','aaa']
# print(l.index('aaa'))
# print(l.index('aaaaaaaaa')) # 找不到报错

10 .clear():清空列表

# l.clear()
# print(l)

11 .reverse():将列表倒置

# l = [1, 'egon','alex','lxx']
# l.reverse()
# print(l)

8 .sort():列表排序(需同种元素)

# l=[11,-3,9,2,3.1]
# l.sort() # 默认从小到大排,称之为升序
# l.sort(reverse=True) # 从大到小排,设置为降序
# print(l)

补充:

1、队列:FIFO,先进先出

# l=[]
# # 入队操作
# l.append('first')
# l.append('second')
# l.append('third')
#
# print(l)
# # 出队操作
# print(l.pop(0))
# print(l.pop(0))
# print(l.pop(0))

2、堆栈:LIFO,后进先出

l=[]
# 入栈操作
l.append('first')
l.append('second')
l.append('third')

print(l)
# 出队操作
print(l.pop())
print(l.pop())
print(l.pop())

4、元组

作用

​ 按照索引/位置存放多个值,只用于读不用于改

定义

  • 元组就是"一个不可变的列表"
  • ()内用逗号分隔开多个任意类型的元素
  • 元组定义好后,内存地址是不能更改的,但对于值是可变类型来说,值仍是可以改变的
# t=(1,1.3,'aa') # t=tuple((1,1.3,'aa'))
# print(t,type(t))

# x=(10) # 单独一个括号代表包含的意思
# print(x,type(x))

# t=(10,) # 如果元组中只有一个元素,必须加逗号
# print(t,type(t))

类型转换

# print(tuple('hello'))
# print(tuple([1,2,3]))
# print(tuple({'a1':111,'a2':333}))

4.1内置方法

1 按索引取值(正向取+反向取):只能取

# t=('aa','bbb','cc')
# print(t[0])
# print(t[-1])

2 切片(顾头不顾尾,步长)

# t=('aa','bbb','cc','dd','eee')
# print(t[0:3])
# print(t[::-1])

3 长度

# t=('aa','bbb','cc','dd','eee')
# print(len(t))

4 成员运算in和not in

# print('aa' in t)

5 循环

# for x in t:
#     print(x)

6 index和count

t=(2,3,111,111,111,111)
# print(t.index(111))#查询值的索引
# print(t.index(1111111111))#找不到就报异常

print(t.count(111))#计算出现次数

5、字典

作用

​ 存放键值对(key : value)

定义;

  • {}内用逗号分隔开多个key:value(键值对)
  • 其中value可以使任意类型,但是key必须是不可变类型,且不能重复

造字典的方式一:

# d={'k1':111,(1,2,3):222} # d=dict(...)
# print(d['k1'])
# print(d[(1,2,3)])
# print(type(d))

# d={} # 默认定义出来的是空字典
# print(d,type(d))

造字典的方式二:

# d=dict(x=1,y=2,z=3)
# print(d,type(d))

造字典的方式三:

# info=[
#     ['name','egon'],
#     ('age',18),
#     ['gender','male']
# ]
# res=dict(info) # 一行代码搞定上述for循环的工作
# print(res)

造字典的方式四:快速初始化一个字典

# keys=['name','age','gender']
# d={}
# for k in keys:
#     d[k]=None
# print(d)
# d={}.fromkeys(keys,None) # 一行代码搞定上述for循环的工作
# print(d)

数据类型转换

# info=[
#     ['name','egon'],
#     ('age',18),
#     ['gender','male']
# ]
# d={}
# for k,v in info: # k,v=['name','egon'],
#     d[k]=v
# print(d)
#

5.1 内置方法

1、按key存取值:可存可取

# d={'k1':111}
# 针对赋值操作:key存在,则修改
# d['k1']=222
# 针对赋值操作:key不存在,则创建新值
# d['k2']=3333

2、长度len

# d={'k1':111,'k2':2222,'k1':3333,'k1':4444}
# print(d)
# print(len(d))

3、成员运算in和not in:根据key

# d={'k1':111,'k2':2222}
# print('k1' in d)
# print(111 in d)

4、删除

  • 通用删除
d={'k1':111,'k2':2222}
# del d['k1']
# print(d)
  • pop删除:根据key删除元素,返回删除key对应的那个value值
d={'k1':111,'k2':2222}
# res=d.pop('k2')
# print(d)
# print(res)
  • popitem删除:随机删除,返回元组(删除的key,删除的value)
d={'k1':111,'k2':2222}
# res=d.popitem()
# print(d)
# print(res)

5、键keys(),值values(),键值对items()

在python2中
>>> d={'k1':111,'k2':2222}
>>> 
>>> d.keys()
['k2', 'k1']
>>> d.values()
[2222, 111]
>>> d.items()
[('k2', 2222), ('k1', 111)]
>>> dict(d.items())
{'k2': 2222, 'k1': 111}

6、for循环

for k in d.keys():
    print(k)
for k in d:
    print(k)
for v in d.values():
    print(v)
for k,v in d.items():
    print(k,v)

print(list(d.keys()))
print(list(d.values()))
print(list(d.items()))

7、d.clear()

d={'k1':111}
d.clear()#清空字典

8、d.update()

d={'k1':111}
# d.update({'k2':222,'k3':333,'k1':111111111111111})
# print(d)

9、d.get() 根据key取值,容错性好

d={'k1':111}
# print(d['k2'])  # key不存在则报错

# print(d.get('k1')) # 111
# print(d.get('k2')) # key不存在不报错,返回None

10、d.setdefault()

  • 如果key有则不添加,返回字典中key对应的值
info={'name':'egon'}
res=info.setdefault('name','egon')
# print(info)

print(res)

  • 如果key没有则添加,返回字典中key对应的值
info={}
res=info.setdefault('name','egon')
# print(info)
print(res)

6. 集合

作用

​ 集合、list、tuple、dict一样都可以存放多个值,

​ 集合主要用于:去重、关系运算

定义:

​ 在{}内用逗号分隔开多个元素,多个元素满足以下三个条件

  • 集合内元素必须为不可变类型
  • 集合内元素无序
  • 集合内元素没有重复
 s={1,2} # s=set({1,2})

 s={1,[1,2]} # 集合内元素必须为不可变类型
 s={1,'a','z','b',4,7} # 集合内元素无序
 s={1,1,1,1,1,1,'a','b'} # 集合内元素没有重复
 print(s)

 s={}# 默认是空字典
 print(type(s))

定义空集合
 s=set()
 print(s,type(s))

类型转换

 set({1,2,3})
 res=set('hellolllll')
 print(res)

 print(set([1,1,1,1,1,1]))
 print(set([1,1,1,1,1,1,[11,222]]) # 报错

 print(set({'k1':1,'k2':2}))

6.1 内置方法

  • 关系运算符
friends1 = {"zero","kevin","jason","egon"}
friends2 = {"Jy","ricky","jason","egon"}

1 取交集:两者共同的好友

 res=friends1 & friends2
 print(res)
 print(friends1.intersection(friends2))

2 取并集/合集:两者所有的好友

 print(friends1 | friends2)
 print(friends1.union(friends2))

3 取差集:(注意:取到的是-前面集合独有的元素)

#取friends1独有的好友
 print(friends1 - friends2)
 print(friends1.difference(friends2))

# 取friends2独有的好友
 print(friends2 - friends1)
 print(friends2.difference(friends1))

4 对称差集: 求两个用户独有的好友们(即去掉共有的好友)

 print(friends1 ^ friends2)
 print(friends1.symmetric_difference(friends2))

5 父子集:包含的关系

 s1={1,2,3}
 s2={1,2,4}
不存在包含关系,下面比较均为False
 print(s1 > s2)
 print(s1 < s2)

 s1={1,2,3}
 s2={1,2}
 print(s1 > s2) # 当s1大于或等于s2时,才能说是s1是s2他爹
 print(s1.issuperset(s2))
 print(s2.issubset(s1)) # s2 < s2 =>True

 s1={1,2,3}
 s2={1,2,3}
 print(s1 == s2) # s1与s2互为父子
 print(s1.issuperset(s2))
 print(s2.issuperset(s1))

去重

6 只能针对不可变类型去重

 print(set([1,1,1,1,2]))

7 无法保证原来的顺序

 l=[1,'a','b','z',1,1,1,2]
 l=list(set(l))
 print(l)

l=[
{'name':'lili','age':18,'sex':'male'},
{'name':'jack','age':73,'sex':'male'},
{'name':'tom','age':20,'sex':'female'},
{'name':'lili','age':18,'sex':'male'},
{'name':'lili','age':18,'sex':'male'},
]
new_l=[]
for dic in l:
if dic not in new_l:
new_l.append(dic)

 print(new_l)

8 长度

s={'a','b','c'}
len(s)
3

9 成员运算

'c' in s
True

10 循环

for item in s:
	print(item)

11 discard

s={1,2,3}
s.discard(4)                        # 删除元素不存在do nothing
 print(s)
 s.remove(4)                       # 删除元素不存在则报错

12 update

 s.update({1,3,5})
 print(s)

13 pop

 res=s.pop()
 print(res)

14 add

 s.add(4)
 print(s)

了解的内置方法

res=s.isdisjoint({3,4,5,6})   # 两个集合完全独立、没有共同部分,返回True
print(res)
 s.difference_update({3,4,5}) # s=s.difference({3,4,5})
 print(s)