整型内置方法:
- 用途:年龄、号码、等级
- 定义:可以使用int()方法将纯数字的字符串转为十进制的整型
age = 19 # age = int(10)
print(type(age))
- 常用操作+内置方法:算术运算+比较运算
长整型
长整型只在python2中存在,python3中不存在长整型
- 存一个值or多个值:一个值
- 有序or无序:无有序or无序一说
可变or不可变
id不变值可变,即在原值的基础上修改,则为可变数据类型;值变id也变,即重新申请一个空间放入新值,则为不可变数据类型。
浮点型内置方法
- .用途:薪资、身高、体重
- 定义:可以使用float()方法将纯数字的字符串转为浮点型数字
- 常用操作+内置方法:算术运算+比较运算
- 存一个值or多个值:一个值
- 有序or无序:无有序or无序一说
- 可变or不可变:不可变数据类型
字符串类型内置方法
1.用途:描述性质的东西,如人的名字、单个爱好、地址、国家等
2.定义:使用''、""、''''''、""""""包裹的的一串字符
- u'unicode': unicode编码的字符串
- b'101': 二进制编码的字符串
- r'\n': 原生字符串,也就是说'\n'这是普通的两个字符,并没有换行的意思
- 按索引取值
- 切片
- 长度len
- 成员运算in|not in
- 移除空白strip
- 切分split
- 循环
- 按索引取值(只可取不可改变)
msg = 'hello nick'
print(f'索引为6: {msg[6]}')
print(f'索引为-3: {msg[-3]}')
- 切片(顾头不顾尾,步长
msg = 'hello nick'
print(f'切片3-最后: {msg[3:]}')
print(f'切片3-8: {msg[3:8]}')
print(f'切片3-8,步长为2: {msg[3:8:2]}')
print(f'切片3-最后,步长为2: {msg[3::2]}')
print('\n了解知识点')
print(f'切片所有: {msg[:]}')
print(f'反转所有: {msg[::-1]}')
print(f'切片-5--2: {msg[-5:-2:1]}')
print(f'切片-2--5: {msg[-2:-5:-1]}')
- 长度len
msg = 'hello nick'
print(len(msg))
- 成员运算in和not in
msg = 'my name is nick, nick handsome'
print(f"'nick' in msg: {'nick' in msg}")
print(f"'jason' not in msg: {'jason' not in msg}")
print(f"not 'jason' in msg: {not 'jason' in msg}")
- 移除空白strip()
name = '&&&n ick'
print(f"name.strip('&'): {name.strip('&')}") # strip()默认为‘ ’,并且不修改原值,新创建空间
print(f"name: {name}")
pwd = input('password: ') # 用户可能会手抖输入空格
if pwd.strip() == '123':
print('密码输入成功')
print(f"'-& nick+'.strip('-& +'): {'-& nick+'.strip('-& +')}")
- 切分split
info = 'nick:male:19'
info_list1 = info.split('😂
info_list2 = info.split(':', 1)
print(f'info_list1:{info_list1}')
print(f'info_list2:{info_list2}')
- 循环
msg = 'hello nick'
for i in msg:
print(i)
- lstrip()和rstrip()
name = '&&nick&&'
print(f"nick.lstrip('&'): {name.lstrip('&')}")
print(f"nick.rstrip('&'): {name.rstrip('&')}")
- lower()和upper()
> name = 'Nick Chen'
print(f"name.upper(): {name.lower()}")
print(f"name.upper(): {name.upper()}")
- startswith()和endswith()
name = 'Nick Chen'
print(f"name.startswith('Nick'): {name.startswith('Nick')}")
print(f"name.endswith('chen'): {name.endswith('chen')}")
- rsplit()
info = 'nick:male:19'
print(f"info.rsplit(':', 1): {info.rsplit(':', 1)}")
- join()
lis = [1,2,'19']
print(f"':'.join(lis): {':'.join(lis)}")
lis = ['nick', 'male', '19']
print(f"':'.join(lis): {':'.join(lis)}")
- replace()
name = 'nick shuai'
print(f"name.replace('shuai','handsome'): {name.replace('shuai','handsome')}")
7.isdigit()
salary = '111'
print(salary.isdigit()) # True
salary = '111.1'
print(salary.isdigit()) # False
- find|rfind|index|rindex|count
- center|ljust|rjust|zfill
- expandtabs
- captalize|swapcase|title
- is系列
- find()、rfind()、index()、rindex()、count()
print(f"msg.find('tank'): {msg.find('tank')}") # 找不到返回-1
print(f"msg.find('tank',0,3): {msg.find('tank',0,3)}")
print(f"msg.rfind('tank'): {msg.rfind('tank')}") # 找不到返回-1
print(f"msg.index('tank'): {msg.index('tank')}") # 找不到报错
print(f"msg.rindex('tank'): {msg.rindex('tank')}") # 找不到报错
print(f"msg.count('tank'): {msg.count('tank')}")
- center()、ljust()、rjust()、zfill()
print(f"'info nick'.center(50,''): {'info nick'.center(50,'')}")
print(f"'info nick'.ljust(50,''): {'info nick'.ljust(50,'')}")
print(f"'info nick'.rjust(50,''): {'info nick'.rjust(50,'')}")
print(f"'info nick'.zfill(50): {'info nick'.zfill(50)}") # 默认用0填充
- expandtabs()
print(f"a\tb\tc: %s"%('a\tb\tc\t')) # 默认制表符8个空格
print(f"'a\tb\tc'.expandtabs(32): %s"%('a\tb\tc\t'.expandtabs(32)))
- captalize()、swapcase()、title()
name = 'nick handsome sWAPCASE'
print(f"name.capitalize(): {name.capitalize()}")
print(f"name.swapcase(): {name.swapcase()}") # 大小写互转
print(f"name.title(): {name.title()}")
- is数字系列(只是为了告诉你,判断是否为数字时除了中文数字以后使用isdigit()即可)
- isdecimal(): 检查字符串是否值包含十进制字符,如果是返回True,否则返回False。
- isdigit(): 如果字符串只包含数字则返回True,否则返回False。
- isnumeric(): 如果字符串中只包含数字字符,则返回True,否则返回False。
- is其他
- isalnum(): 如果字符串至少有一个字符并且所有字符都是字母或数字则返回True,否则返回False。
- isalpha(): 如果字符串至少有一个字符并且所有字符都是字母则返回True,否则返回False。
- islower(): 如果字符串中只包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回True,否则返回False。
- isspace(): 如果字符串中只包含空白,则返回True,否则返回False
- isupper(): 如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回True,否则返回False。
- istitle(): 如果字符串是标题类型的(见title()),则返回True,否则返回False。
- 存一个值or多个值:一个值
- 有序or无序:只要是有索引的,都是有序的,因此字符串是有序的。
name = 'nick'
print(f'first:{id(name)}')
name = 'nick handsome'
print(f'second:{id(name)}')
first:4377100160
second:4377841264
- 可变or不可变:不可变数据类型
列表类型内置方法
- 一. 列表类型内置方法:
- 用途:多个装备、多个爱好、多门课程,甚至是多个女朋友
- .定义:[]内可以有多个任意类型的值,逗号分隔元素
- 常用操作+内置方法:常用操作和内置方法分为优先掌握(今天必须得记住)、需要掌握(一周内记住)、其他操作(了解)三个部分
优先掌握:
-
- 按索引取值(正向取值+反向取值),即可存也可以取
-
- 切片
-
- 长度len
-
- 成员运算in和not in
-
- 追加append
-
- 删除del
-
- 循环
需要掌握:
-
- insert
-
- pop
-
- remove
-
- count
-
- index
-
- clear
-
- copy
-
- extend
-
- reverse
-
- sort
元组类型内置方法
- 一. 元组类型内置方法
- 用途:多个装备、多个爱好、多门课程,甚至是多个女朋友
- 定义:在()内可以有多个任意类型的值,逗号分隔元素
优先掌握:
-
- 索引取值
-
- 切片(顾头不顾尾,步长)
-
- 长度len
-
- 成员运算in和not in
-
- 循环
-
- count
-
- index
- 二. 元组和列表的区别
列表可变的原因是:索引所对应的值的内存地址是可以改变的
元组不可变得原因是:索引所对应的值的内存地址是不可以改变的,或者反过来说,只要索引对应值的内存地址没有改变,那么元组是始终没有改变的。
集合类型内置方法
- 用途:用于关系运算的集合体,由于集合内的元素无序且集合元素不可重复,因此集合可以去重,但是去重后的集合会打乱原来元素的顺序。
- 定义:{}内用逗号分隔开多个元素,每个元素必须是不可变类型。
- 常用操作+内置方法:常用操作和内置方法分为优先掌握(今天必须得记住)、需要掌握(一周内记住)两个部分。
优先掌握
-
- 长度len
-
- 成员运算in和not in
-
- |并集、union
-
- &交集、intersection
-
- -差集、difference
-
- ^对称差集、symmetric_difference
-
- ==
-
- 父集:>、>= 、issuperset
-
- 子集:<、<= 、issubset
需要掌握
-
- add
-
- remove
-
- difference_update
-
- discard
-
- isdisjoint