一、可变不可变类型
1、可变类型:值改变,但是id不变,证明就是在改变原值,是可变类型
2、不可变类型:值改变,id也变,证明是产生了新值,并没有改变原值,原值是不可变类型
#数字 x = 123 print(id(x))#8791380317664 x = 456 print(id(x))#31218128 #列表 l1=[111,222,333] print(id(l1))#31582720 l1[0] = 1111111111111111 print(l1)#[1111111111111111, 222, 333] print(id(l1))#31582720
ps:python是一门解释型 强类型 动态语言
二、数字类型及其常用操作
整型int
1、用途:年龄、个数、号码、出生年等
2、定义方式
age = 18 # age = int(18)
# int功能可以把纯整数数字的字符串转换成int类型,float不行,会直接报错。
res = int("18")#<class 'int'> # res = int("1.8")#float类型会报错 print(type(res))
了解(***)
#进制转换 print(bin(11)) # 0b1011 print(oct(11)) # 0o13 print(hex(11)) # 0xb
3、常用操作+内置的方法
算数运算符与比较运算
浮点型float
1、用途:薪资、身高、体重等
2、定义方式
salary = 3.1 # salary = float(3.1)
# float功能可以把浮点数组成的字符串转换成float类型
res = float("1.8") print(type(res))#<class 'float'>
3、常用操作+内置的方法
算数运算符与比较运算
总结:
数字类型都是只能存一个值,是不可变类型
无常用操作,无内置的方法
三、字符串类型及其常用操作
1、用途:记录描述性质的状态,例如名字、性别、国籍等
2、定义方式:在引号('',"",'''''',""""""")内包含一串字符串
# str功能可以把任意类型转换成str类型
res=str([1,2,3]) print(res,type(res))# "[1,2,3]" <class 'str'>
3、常用操作+内置的方法
=========优先掌握的操作=========
1、按索引取值(正向取+反向取) :只能取
s = "hello world" print(s[0],type(s[0])) # "h" <class 'str'> print(s[-1])#'d' # s[1] = "E" # 报错,不能修改 # s[2222]# 非法操作 # s[11] = "A" #超出索引,#非法操作
2、切片(顾头不顾尾,步长)=>属于拷贝操作
#可以省略步长,默认为1
#可以省略起始位置与步长,默认起始位置为0 步长为1
s = "hello world" # new_s=s[1:7] # print(new_s) # print(s) # new_s=s[1:7:2] #1 3 5 # print(new_s) # print(s) # new_s=s[:7:2] # new_s=s[::2] # 0 2 4 6 8 10 # h l o w r d # print(new_s) # new_s=s[::] # 完整拷贝字符串,只留一个冒号就可以new_s=s[:] # print(new_s)
3、长度len
s = "hello world" print(len(s)) res=print("sfd") print(res)
4、成员运算in和not in
s = "hello world" print("hel" in s) print("egon" not in s) # 语义明确,推荐使用 # print(not "egon" in s)
5、移除左右两边空白( 也算空白)strip 移除左右两边特定的字符,空白也是字符
s = " hel lo " new_s = s.strip() print(new_s) print(s) # 没有改变原字符串
# 应用案列: # name = input("your name>>> ").strip() # name = "egon " # pwd = input("your pwd>>> ").strip()
去除左右两边的非空白字符strip
print("**+=-%^#*$^&@!***he**llo**%^#**+=**".strip("*+=-%^$^@!&#"))
6、切分split:把字符串按照某个分隔符切成一个列表
userinfo = "egon_dsb:123:18:3.1" res = userinfo.split(":") print(res)#['egon_dsb', '123', '18', '3.1'] 注意得到的是列表 print(res[0])#egon_dsb
# 纯字符串组成的列表
l = ["aaaa", "bbb", "ccc"] # res=l[0]+":"+l[1]+":"+l[2]#原始方式,利用字符串相加 res = ":".join(l) #join方式 print(res, type(res)) #aaaa:bbb:ccc <class 'str'>
7、join 连接的元素必须是字符串
userinfo = "egon_dsb:123:18:3.1"#字符串 print("-".join(userinfo))#e-g-o-n-_-d-s-b-:-1-2-3-:-1-8-:-3-.-1 userinfo = "egon_dsb:123:18:3.1" res = userinfo.split(":")#得到列表['egon_dsb', '123', '18', '3.1'] print("-".join(res)) #egon_dsb-123-18-3.1
7、循环
for i in "hello": print(i)
==========需要掌握的操作=========
1、strip,lstrip,rstrip
print("***hello***".strip("*")) print("***hello***".lstrip("*")) print("***hello***".rstrip("*"))
2、lower,upper
msg = "AbCDEFGhigklmn" res1 = msg.lower() res2 = msg.upper() print(res1) print(res2)
3、swapcase大小写反转
msg = "AbCDEFGhigklmn" res3=msg.swapcase() print(res3)
4、startswith,endswith
msg = "sb is lxx sb" print(msg.startswith("sb"))#True print(msg.endswith("b"))#True print(msg.endswith("c"))#False
5、split,rsplit
userinfo="egon:123:18" print(userinfo.split(":"))#['egon', '123', '18'] print(userinfo.split(":",1))#['egon', '123:18'] print(userinfo.rsplit(":",1))#['egon:123', '18']
6、replace replace('原值','现值')
msg = "***egon hello***" res=msg.replace('*','').replace(' ','') res1=msg.strip('*').replace(' ','') print(res) print(res1)
print(msg)#不变
7、format的三种玩法
(1)%s的方式
(2)format的方式
(3)f'' (不要乱用python3.6开始才有此功能)
#(1)%s的方式 name = "egon" age = 18 res1="my name is %s my age is %s" % (name,age) print(res1) #(2)format的方式 name = "egon" age = 18 res1="my name is {} my age is {}".format(name,age) res2="{0}{0}{0}{1}".format(name,age)#egonegonegon18 res3="my name is {name} my age is {age}".format(age=18,name="egon") print(res1) print(res2) print(res3) #(3)f'' name = "egon" age = 18 res1 = f'my name is {name} my age is {age}' print(res1)
了解:f搭配{}可以执行字符串中的代码
res=f'{len("hello")}' print(res) f'{print("hello")}'
f包含的字符串可以放到多行
name = "egon" age = 18 res1 = f"my name is {name} " f"my age is {age}" print(res1)
# {}内不能有以及# 外层{}有取消掉内层{}的意思
print(f'my name is {{egon}}')#{}类似于 print('胜率是 %s%%' %70)
8、isdigit:判断字符串是否由纯数字组成,只能判断整形
print("adsf123".isdigit())#False print("123".isdigit())#True print("12.3".isdigit())#False
age = input('>>>: ') # age = " 18 " if age.isdigit():#可先判断是否为数字,减少程序bug age=int(age) if age > 18: print('猜大了') elif age < 18: print('猜小了') else: print('猜对了') else: print('必须输入数字,小垃圾')
==========需要了解的操作=========
1、find,rfind,index,rindex,count
总结:find 查找找到所要查找的位置的索引值,结果为-1代表没找到;
rfind从右往左开始查找找到所要查找的索引的位置
index查找找到所要查找的位置的索引值,找不到报错
rindex从右往左查找,找不到报错
count计数
x = "hello egon egon egon" # res=x.find("egon") #代表从索引6开始 # res=x.find("egon123") # -1代表没有找到 # print(res) res=x.rfind("egon") print(res) res=x.find("egon",0,3)#从索引0 到3里查找 print(res) #index # res = x.index("egon123") # 找不到则报错 res = x.index("egon") # 代表从索引6开始 print(res) #count a = "hello,world!" d = {} for i in a: d[i] = a.count(i) print (d)#{'h': 1, 'e': 1, 'l': 3, 'o': 2, ',': 1, 'w': 1, 'r': 1, 'd': 1, '!': 1}
2、center,ljust,rjust,zfill
总结:center居中;
ljust居左;
rjust居右;
zfill居右,用0补全,默认右对齐
x = "egon" print(x.center(50,'*'))#居中,共50的字符,除了x外其余用*填满 print(x.ljust(50,"*"))#居右,共50的字符,除了x外其余用*填满 print(x.rjust(50,"*"))#居左,共50的字符,除了x外其余用*填满 print(x.zfill(50))#居右,共50的字符,除了x外其余默认用0填满 print(x.rjust(50,"0"))#居右,共50的字符,除了x外其余用0填满
3、expandtabs展开选项卡----指定 制表符的长度
expandtabs() 方法把字符串中的 tab 符号(' ')转为空格,tab 符号(' ')默认的空格数是 8。
从头开始数,数到第一个 正好为8个空格,不足则补空格,如果还有 ,接着从第一个 数到第二个 仍然为8个空格,以此类推直到最后一个 结束。
print("hello world".expandtabs(1)) #hello world 长度为11 print("hello world".expandtabs(2)) #hello world长度为11 print("hello world".expandtabs(3)) #hello world长度为11 print("hello world".expandtabs(4)) #hello world长度为13 print("hello world".expandtabs(5)) #hello world长度为15 print("hello world".expandtabs(6)) #hello world长度为11
4、captalize,swapcase,title
总结:captalize首字母大写
swapcase大小写翻转
title每个单词首字母大写 利用IDE开发工具,自动提示的功能
print("hello world egon".capitalize())#首字母大写 print("aBcDeF".swapcase())#大小写翻转 print("hello world egon".title())#每个单词首字母大写
5、is其他
name='egon123' print(name.isalnum()) #字符串由字母或数字组成 print(name.isalpha()) #字符串只由字母组成 name="aaainputbbbbb" print(name.isidentifier())# name="abc123" print(name.islower())#是否都是大写 print(name.isupper())#是否都是小写 name=" " print(name.isspace())#字符串是否为空 name="My Name Is Egon" print(name.istitle())#字符串每个单词首字母为大写
6、is数字系列
#在python3中 num1=b'4' #bytes num2=u'4' #unicode,python3中无需加u就是unicode num3='四' #中文数字 num4='Ⅳ' #罗马数字
#1、 bytes、unicode # print(num1.isdigit()) # print(num2.isdigit()) # print(num3.isdigit()) # print(num4.isdigit()) # 2、unicode、中文数字、罗马数字 # print(num2.isnumeric()) # print(num3.isnumeric()) # print(num4.isnumeric()) # 3、unicode # print(num2.isdecimal()) # print(num3.isdecimal()) # print(num4.isdecimal())
str类型总结:
存一个值,有序,不可变