一.常用的字符串方法
capitalize() #将字符串首字母大写
center(100,'*') #把字符串居中的
count(‘zhou’)#查询次数
endswith('.jpg ')#判断字符串是否以XXX结尾;返回类型为布尔类型,True 或者False
startswith(‘138’)#判断字符串是否以xxx开头
upper()#都给你变成大写
lower()#都给你变成小写
find(‘a’)#找字符串的下标,找不到不会报错,返回-1
index(‘a’)#找字符串的下标,找不到会报错
isdigit()# 判断是否为纯数字
isspace()#判断是否全是空格
isalnum()#只能有英文或数字
isalpha()只能有英文、汉字
strip()#去掉字符串两边的东西,默认是去掉两边的空格和换行符的
lstrip()#只去掉左边的
rstrip()#只去掉右边的
replace(‘123’,‘456’)#替换字符串,把前面的替换成后面的,第三个参数是替换的处数,默认替换全部
istitle()#标题,首字母为大写即标题
zfill()# 在前面补0
eg:name ='5'
print(name.zfill(2)
结果 05
split(‘,’)#1.分割字符串 2.把字符串变成一个list 3.默认是以空格和换行符分割的
join()#1.把list变成字符串的 2.以某个字符串连接
二、 切片、循环list
1.循环list、循环字符串同
eg:stus = ['abc','tzy','nihao']
for stu in stus:
print(stu)
2.切片,list取值的一种方式
stus = ['abc','tzy','nihao']
stus[1:2]#顾头不顾尾,能取到‘tzy’,取不到‘nihao’
stus[:3]#从头开始可不写
stus[1:]#如果后面的下标不写的话,代表取到结尾
stus[:]#开头的下标和结尾的下标都不写,代表取到整个list
stus[-1]#-1代表最后一个元素
eg:import string
string.digits.split()
结果:['0123456']
nums = list(string.digits)
print(nums)
结果:['0','1','2','3','4','5','6','7','8','9']
print(nums[0:11:2])#第二冒号后面值代表步长,是隔几个元素取一次
结果:['0','2','4','6','8']
print(nums[::-1])#步数是负数从右往左开始取值,反转
print(nums[1:5:-1])
print(nums[-6:-10:-1])
#切片同样适用于字符串
3.元组
#元组 list 但它不可变 一旦定义好就不能再变
cities = ('beijing','shanghai')
#元组取值,取下标
print(cities[0])
print(cities.count('beijing'))#数出现的次数
print(cities.index('beijing'))#取下标
#字符串定义好后,也不能修改,只能重定义
eg:s='abcEFGabc'
s = s.replace('abc','')
print(s)
结果:EFG
三、list循环删元素、变量存储方式
eg:
a=[1,1,2,3,4,5,6,72]
b=[1,1,2,3,4,5,6,72]
# 0 1 2 3 4 5 6 7
[1,2,3,4,5,6,72]
for i in b:#i是list里的元素
if i%2!=0:
a.remove(i)
print(a)
结果:[1,2,4,6,72]
原因:下标错乱
解决办法:再定义一个一模一样的list,循环一个list,删另一个list
b=a[:]
print(id(a)# 打印a的内存地址
a=b=c=d=0
e,f,g=1,2,3
a,b=1,2 #交换a、b的值
b,a=a,b#python中可以直接交换,自动引入了第三方变量
四、字典
1.非空即真,非0即真
eg:
a1=1
b1=2
print(a1==b1)
结果:False
a=[]
b=''
c=()
d=0
e=None
if a: #如果a有值
print('是真的')
else:
print('是假的')
结果:是假的
import this #python的话
#not的意思是取反
m=‘好’
print(not m)
结果:False
2.字典
# k - v
d = {}
zjr={‘name‘’:‘zhoujirong’,
‘age‘:‘18’,
‘sex’:‘女’,
‘qq’:‘13242452’}
#字典的k唯一,相同k会取最后一个
#字典是无序的
#增加
zjr['身高’]=’165'
#修改
zjr['age']=35#有的话就改,无的话加
zjr.setdefault('age',50)#如果key已经存在,就不会修改,若不存在,加
#删除
zjr.pop('qq')#指定key删掉,key不存在会报错
del zjr['age']#del删除,key不存在会报错
zjr.clear()#清空字典
zjr.popitem()#随机删除一个key
#取值
zjr['name']#不存在会报错
zjr.get('email','[email protected]')#key不存在返回None,第二个参数是若值为空取默认
‘age’ in data: #判断data字典里是否有‘age’这个key
tzy={'name1':'pig','age':20}
zjr.update(tzy)#把一个字典加入另一个字典里面
print(zjr.values())
print(zjr.keys()) for i in zjr:
print(i)#循环打印的是字典的key
for k,v in zjr.items():
print(k,v) #能同时取到key和value
print(zjr)
高效循环字典的方式
d = {'a':1,'b':2}
print(d.items())
for k,v in d.items():
print(k,v)
for k in d:
print(k,d.get(k))
#记录学生是否交作业的小程序
#学生名字 日期 状态
data ={
'zjr':{
'2018-6-3':'未交'
},
'pig':{
'2018-6-7':'已交'
}
} for i in range(2): name =input('name:').strip()
date = input('date:').strip()
status = input('status'.strip())#可以不写,如果不写的话,是未交
if name and date:# 判空,如果name和date都不为空,状态为空时默认为未交
status = '已交' if status else '未交'#三元表达式
if name in data:
data[name][date]=status
else:
tmp = {date:status}#{'2018-2-3':'未交'},#data[name]= {date:status}先构造一个小字典
data[name]=tmp#再给外面这个大字典加一个学生 value这个小字典
print('添加之后的',data) else:
print('姓名和日期不能为空!')
#注意:
status = '已交' if status else '未交' #三元表达式
#上面的一行和下面的四行是一样的
if status:
status = '已交'
else:
status = '未交'
五、文件读写
1.打开文件
#2.对他读或写
#3.关闭文件 #open() file()
#1.有没有清空内容
#2.能不能读到东西
#3.文件不存在会不会报错
f = open(r'C:\Users\Mezhou\PycharmProjects\untitled\zjr','a+',encoding='utf-8') #写路径之前加r,当前目录直接写文件名
# print(f.read())
#文件指针
# print('readline',f.readline())#读取文件一行的数据 # names = ['abc','zjr','tzy','hdhsh']
# for name in names:
# f.write(name+'\n')
# f.writelines(names)#传一个list,然后把list里面的每一个元素写入到文件中
f.seek(0)
print('readlines',f.readlines())#获取文件里面的所有内容,每一行的数据放到一个list里面
# print('read',f.read())#获取文件里的所有内容
#f.write('789') # f.seek(0)#移动文件指针到最前面
# print('read',f.read())
# f.close() #只读模式 r 读写模式 r+
#只能读 文件不存在会报错 可读可写,打开不存在的时候也会报错 #写模式 w
#会覆盖以前文件里的内容,不能读 文件不存在的话,会帮你创建一个
#写读模式 w+ 会清空以前的数据
#只要粘上r,文件不存在就会报错
#只要粘上w,文件内容肯定会被清空 #追加模式 a+
#能读、能写、不会清空以前的内容,文件不存在会创建 # print(f.read())
# names =['a','a1','g3']
# for i in names:
# f.write(names+'\n')