数据类型
数字(整形,长整形,浮点型,复数)
字符串
列表
元组
字典
集合
一.数字
作用:年纪,等级,薪资,身份证号,qq号等数字相关
定义:
age=10 #本质age=int(10)
salary=3000.3 #本质salary=float(3000.3)
二进制,十进制,八进制,十六进制
二.字符串
#strip
name='*egon**'
print(name.strip('*'))
print(name.lstrip('*'))
print(name.rstrip('*'))
#startswith,endswith
name='alex_SB'
print(name.endswith('SB'))
print(name.startswith('alex'))
#replace
name='alex say :i have one tesla,my name is alex'
print(name.replace('alex','SB',1))
#format的三种玩法
res='{} {} {}'.format('egon',18,'male')
res='{1} {0} {1}'.format('egon',18,'male')
res='{name} {age} {sex}'.format(sex='male',name='egon',age=18)
#find,rfind,index,rindex,count
name='egon say hello'
print(name.find('o',1,3)) #顾头不顾尾,找不到则返回-1不会报错,找到了则显示索引
# print(name.index('e',2,4)) #同上,但是找不到会报错
print(name.count('e',1,3)) #顾头不顾尾,如果不指定范围则查找所有
#split
name='root:x:0:0::/root:/bin/bash'
print(name.split(':')) #默认分隔符为空格
name='C:/a/b/c/d.txt' #只想拿到顶级目录
print(name.split('/',1))
name='a|b|c'
print(name.rsplit('|',1)) #从右开始切分
#join
tag=' '
print(tag.join(['egon','say','hello','world'])) #可迭代对象必须都是字符串
#center,ljust,rjust,zfill
name='egon'
print(name.center(30,'-'))
print(name.ljust(30,'*'))
print(name.rjust(30,'*'))
print(name.zfill(50)) #用0填充
#expandtabs
name='egon\thello'
print(name)
print(name.expandtabs(1))
#lower,upper
name='egon'
print(name.lower())
print(name.upper())
#captalize,swapcase,title
print(name.capitalize()) #首字母大写
print(name.swapcase()) #大小写翻转
msg='egon say hi'
print(msg.title()) #每个单词的首字母大写
#is数字系列
#在python3中
num1=b'4' #bytes
num2=u'4' #unicode,python3中无需加u就是unicode
num3='四' #中文数字
num4='Ⅳ' #罗马数字
#isdigt:bytes,unicode
print(num1.isdigit()) #True
print(num2.isdigit()) #True
print(num3.isdigit()) #False
print(num4.isdigit()) #False
#isdecimal:uncicode
#bytes类型无isdecimal方法
print(num2.isdecimal()) #True
print(num3.isdecimal()) #False
print(num4.isdecimal()) #False
#isnumberic:unicode,中文数字,罗马数字
#bytes类型无isnumberic方法
print(num2.isnumeric()) #True
print(num3.isnumeric()) #True
print(num4.isnumeric()) #True
#三者不能判断浮点数
num5='4.3'
print(num5.isdigit())
print(num5.isdecimal())
print(num5.isnumeric())
'''
总结:
最常用的是isdigit,可以判断bytes和unicode类型,这也是最常见的数字应用场景
如果要判断中文数字或罗马数字,则需要用到isnumeric
'''
#is其他
print('===>')
name='egon123'
print(name.isalnum()) #字符串由字母和数字组成
print(name.isalpha()) #字符串只由字母组成
print(name.isidentifier())
print(name.islower())
print(name.isupper())
print(name.isspace())
print(name.istitle())
三.列表
作用:多个装备,多个爱好,多门课程,多个女朋友等
定义:[ ]内可以有多个任意类型的值,逗号分隔
list=['name','age','sex']
print(list) #打印列表
print(list[1]) #根据下标索引打印相应列表内容
print(list[0:1]) #根据下标索引打印范围内容
list.append('hobby') #从列表后面增加元素
list.index(1,'contrucy') #执行索引插入元素
list.pop() #从后往前弹出元素
list.pop(0) #指定下标弹出元素
list.remove('sex') #指定元素弹出
list.clear() #清空列表
print(list.count('age')) #统计元素中相应元素个数
list2=list.copy() #copy列表
list.extend([1,2,3]) #合并增加一个新列表
print(list.index('age')) #相应元素的索引
list.reverse() #列表数据翻转
list.sort() #排序,需要元素是数字
堆栈:先进后出
队列:先进先出
列表根据索引赋值
list=[1,2,3]
a,b,c=list
print(a,b,c)
字符串方法类似 msg='hello' a,b,c,d=msg 如果不想取中间的值 a,_,_,d=msg 或 a,*_,b=msg
四.元组
tuple=('name','age','sex')
元组不可变
print(list) #打印元组
print(list[1]) #根据下标索引打印相应元组内容
print(list[0:1]) #根据下标索引打印范围内容
print(len(tuple)) #长度
浙公网安备 33010602011771号